好吧,假设我有这个

<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();

但这并不奏效。


当前回答

当使用.each(function()…)“循环”动态创建的选择元素时:$("option:selected").text();$(this + " option:selected").text()没有返回所选的选项文本——而是为空。

但彼得·莫滕森的解决方案奏效了:

$(this).find("option:selected").text();

我不知道为什么通常的方法在.each()中没有成功(可能是我自己的错误),但是谢谢你,彼得。我知道这不是最初的问题,但我提到它是“针对谷歌的新手”。

我将从$('#list选项:selected").each()开始,除非我需要从选择元素中抓取东西。

其他回答

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

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

我想要得到选定的标签。这在jQuery 1.5.1中是可行的。

$("#list :selected").text();

试试下面的方法:

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

最初的代码片段不能正常工作的原因是OPTION标记是SELECT标记的子标记,SELECT标记具有id列表。

我想要一个动态版本的选择倍数,将显示什么被选择到右边(希望我读到并看到$(this).find…早些时候):

<script type="text/javascript">
    $(document).ready(function(){
        $("select[showChoices]").each(function(){
            $(this).after("<span id='spn"+$(this).attr('id')+"' style='border:1px solid black;width:100px;float:left;white-space:nowrap;'>&nbsp;</span>");
            doShowSelected($(this).attr('id'));//shows initial selections
        }).change(function(){
            doShowSelected($(this).attr('id'));//as user makes new selections
        });
    });
    function doShowSelected(inId){
        var aryVals=$("#"+inId).val();
        var selText="";
        for(var i=0; i<aryVals.length; i++){
            var o="#"+inId+" option[value='"+aryVals[i]+"']";
            selText+=$(o).text()+"<br>";
        }
        $("#spn"+inId).html(selText);
    }
</script>
<select style="float:left;" multiple="true" id="mySelect" name="mySelect" showChoices="true">
    <option selected="selected" value=1>opt 1</option>
    <option selected="selected" value=2>opt 2</option>
    <option value=3>opt 3</option>
    <option value=4>opt 4</option>
</select>

它在寻找一个id为list的元素它的属性值为2。 你想要的是列表的option子元素:

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