首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用变量的内容而不是ID来选择下拉列表中的项?

如何使用变量的内容而不是ID来选择下拉列表中的项?
EN

Stack Overflow用户
提问于 2020-09-11 00:24:41
回答 2查看 36关注 0票数 1

我有一个包含以下项目的下拉列表:

东开普省,ID =1豪登省,ID =2 KwaZulu Natal,ID 3姆普马兰加,ID 4

我也有一个名为省份的变量。例如,如果我将东开普省放在变量中,并使用以下代码选择东开普省,它不会被选中。

代码语言:javascript
复制
var provinces = "Eastern Cape";
$("#Province").val(provinces); 

但是当我使用下面的代码时,会选择东开普省。

代码语言:javascript
复制
var provinces = 1;
$("#Province").val(provinces);

我想使用省的名称,而不是省的ID,我该怎么做?

问候Siyabonga

EN

回答 2

Stack Overflow用户

发布于 2020-09-11 00:46:44

你应该检查选项的内容,如下所示:

代码语言:javascript
复制
var provinces = "Eastern Cape";
$("#Province option:contains(" + provinces + ")").attr('selected', 'selected');

对于类似的选项,请使用以下命令:

代码语言:javascript
复制
$("#Province  option").each(function() {
  if($(this).text() == provinces ) {
    $(this).attr('selected', 'selected');            
  }                        
});
票数 2
EN

Stack Overflow用户

发布于 2020-09-11 00:36:13

您可以获取包含所需文本的选项,并使用它的value来设置下拉列表,如下所示,它使用jquery

代码语言:javascript
复制
//use .filter() to get the option from the drop down with text = the required text
//then pass it's value to .val() of the dropdown
$('#Province').val($('#Province option').filter(function () { 
    return $(this).html() == "Eastern Cape"; }).val());

您可以将其转换为一个函数,以便更动态地使用:

代码语言:javascript
复制
function setDropdownByOptionText(dropdown, optionText){
     $(dropdown).val($(dropdown).find('option').filter(function () {
          return $(this).html() == optionText; }).val());
}

然后你可以这样叫它:

代码语言:javascript
复制
setDropdownByOptionText($('#Province'), "Eastern Cape");
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63833882

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档