通常我使用$(“#id”).val()来返回所选选项的值,但这一次它不起作用。
所选标记的id为aioConceptName
html代码
<label for="name">Name</label>
<input type="text" name="name" id="name" />
<label for="aioConceptName">AIO Concept Name</label>
<select id="aioConceptName">
<option>choose io</option>
<option>roma</option>
<option>totti</option>
</select>
要用jQuery找到正确的选择,请考虑在html树中可以使用多个选择,这会混淆您的预期输出。
(:selected).val()或(:selected).text()在多个选择选项上不能正确工作。因此,像.map()所做的那样,我们先保留所有选择的数组,然后返回所需的参数或文本。
下面的示例说明了这些问题,并提供了一种更好的方法
<select id="form-s" multiple="multiple">
<option selected>city1</option>
<option selected value="c2">city2</option>
<option value="c3">city3</option>
</select>
<select id="aioConceptName">
<option value="s1" selected >choose io</option>
<option value="s2">roma </option>
<option value="s3">totti</option>
</select>
<select id="test">
<option value="s4">paloma</option>
<option value="s5" selected >foo</option>
<option value="s6">bar</option>
</select>
<script>
$('select').change(function() {
var a=$(':selected').text(); // "city1city2choose iofoo"
var b=$(':selected').val(); // "city1" - selects just first query !
//but..
var c=$(':selected').map(function(){ // ["city1","city2","choose io","foo"]
return $(this).text();
});
var d=$(':selected').map(function(){ // ["city1","c2","s1","s5"]
return $(this).val();
});
console.log(a,b,c,d);
});
</script>
在变体a, b中,与正确工作的c和d相比,它将所有选择保存在数组中,然后返回您所寻找的内容,从而看到不同的容易出现错误的输出。
如果你在事件上下文中,在jQuery中,你可以使用以下方法检索所选的选项元素:
$(this).find('option:selected')如下所示:
$('dropdown_selector').change(function() {
//Use $option (with the "$") to see that the variable is a jQuery object
var $option = $(this).find('option:selected');
//Added with the EDIT
var value = $option.val();//to get content of "value" attrib
var text = $option.text();//to get <option>Text</option> content
});
Edit
正如possession within所提到的,我的答案只是回答这个问题:如何选择所选的“选项”。
接下来,要获取选项值,使用option.val()。
读取select对象的值(而不是文本):
var status = $("#Status").val();
var status = $("#Status")[0].value;
var status = $('#Status option:selected').val();
如何禁用选择?
在这两个变量中,value可以使用以下命令更改:
A
用户无法与下拉菜单进行交互。他不知道还有什么其他选择。
$('#Status').prop('disabled', true);
B
用户可以在下拉菜单中看到选项,但所有选项都是禁用的:
$('#Status option').attr('disabled', true);
在这种情况下,$("#Status").val()只适用于小于1.9.0的jQuery版本。所有其他变体都可以工作。
如何更新一个禁用的选择?
从后面的代码中,您仍然可以更新您选择的值。仅对用户禁用:
$("#Status").val(2);
在某些情况下,你可能需要触发事件:
$("#Status").val(2).change();
JQuery:
如果你想要得到选定的选项文本,你可以使用$(select element).text()。
var text = $('#aioConceptName选项:selected').text();
如果你想要得到选定的选项值,你可以使用$(select element).val()。
var val = $('#aioConceptName选项:selected').val();
确保在<option>标签中设置value属性,如:
<选择id = " aioConceptName " >
<option value="">choose io</option> .
<选项值=“罗马(值)" >罗马(文本)< /选项>
<选项值= "托蒂(值)" >托蒂(文本)< /选项>
< /选择>
在这个HTML代码示例中,假设选择了最后一个选项:
Var text会给你totti(text)
Var val会给你totti(value)
美元(文档)。(“改变”,“# aioConceptName”功能(){
var val = $('#aioConceptName选项:selected').val();
var text = $('#aioConceptName选项:selected').text();
$ (' .result ')。text("Select Value = " + val);
$ (' .result ')。append("<br>Select Text = " + Text);
})
< script src = " https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js " > < /脚本>
<选择id = " aioConceptName " >
<选项值= " io(值)“>选择io > < /选项
<选项值=“罗马(值)" >罗马(文本)< /选项>
<选项值= "托蒂(值)" >托蒂(文本)< /选项>
< /选择>
< p class = "结果" > < / p >
只有一种正确的方法来查找所选的选项-按选项值属性。就拿这段简单的代码来说:
//find selected option
$select = $("#mySelect");
$selectedOption = $select.find( "option[value=" + $select.val() + "]" );
//get selected option text
console.log( $selectedOption.text() );
如果你有一个这样的列表:
<select id="#mySelect" >
<option value="value1" >First option</option>
<option value="value2" >Second option</option>
<option value="value3" selected >Third option</option>
</select>
如果您使用所选属性作为选项,那么find(“:selected”)将给出不正确的结果,因为所选属性将永远停留在选项中,即使用户选择了另一个选项。
即使用户选择第一个或第二个选项,$("select option:selected")的结果也会给出两个元素!因此$("select:selected").text()会给出类似First option Third option的结果
所以使用值属性选择器,不要忘记为所有选项设置值属性!