好吧,假设我有这个

<select id='list'>
    <option value='1'>Option A</option>
    <option value='2'>Option B</option>
    <option value='3'>Option C</option>
</select>

如果我想在值为“2”时获得“Option B”,选择器会是什么样子?

请注意,这并不是询问如何获取所选文本值,而是询问它们中的任何一个,无论是否被选中,这取决于value属性。我试着:

$("#list[value='2']").text();

但这并不奏效。


当前回答

$("#list [value='2']").text();

在id选择器后留下一个空格。

其他回答

$("#list option:selected").each(function() {
   alert($(this).text());
});  

用于#list元素中的多个选定值。

$(this).children(":selected").text()

提示:如果你的值是动态的,你可以使用下面的代码:

$("#list option[value='"+aDynamicValue+"']").text();

或者(更好的风格)

$("#list option").filter(function() {
     return this.value === aDynamicValue;
}).text();

正如在jQuery中提到的,获取特定的选项标签文本并将动态变量放置到值中

作为另一种解决方案,你也可以使用jQuery选择器的上下文部分来在下拉列表中找到值="2"的<option>元素:

$("option[value='2']", "#list").text();

基于Paolo发布的原始HTML,我想出了以下内容。

$("#list").change(function() {
    alert($(this).find("option:selected").text()+' clicked!');
});

经过测试,它可以在ie和Firefox浏览器上运行。