javascript - 使用下拉列表选择填充第二个下拉列表内容

标签 javascript jquery drop-down-menu selector taffydb

下面的代码使用不同的裤子品牌填充第一个下拉列表:

$.each(pantsBrands, function(i){
    var li = $('<li>')
        .appendTo(pantsList);
    var aaa = $('<a>')
        .text(pantsBrands[i])
        .attr('onclick','askPantStyle()')
        .appendTo(li);
});

在接下来的代码中,我打算以某种方式使用上面的选择来填充第二个下拉框中的内容,该下拉框中由与第一个下拉框中选择的品牌相关的样式组成。

var askPantStyle = function(){
    $('#pantStyleDiv').slideDown();
    alert($(this).text());
}

我使用警报来检查(这个)会返回什么。我本来希望是第一个选择的文本内容,但是当出现警告框时,内容是空的。

相关html如下:

<div id='pantsLanding'>
            <p class="lead">Which brand of pants fits you best?</p>
            <p class="lead">
                <!-- Split button -->
                <div class="btn-group">
                    <button type="button" class="btn btn-default">Brand</button>
                    <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
                        <span class="caret"></span>
                        <span class="sr-only">Toggle Dropdown</span>
                    </button>
                    <ul id="dropPants" class="dropdown-menu scrollable-menu" role="menu">
                    </ul>
                </div>
            </p>  
        </div>
        <div id='pantStyleDiv'>
            <p class="lead">What style do you prefer?</p>
            <p class="lead">
                <!-- Split button -->
                <div class="btn-group">
                    <button type="button" class="btn btn-default">Style</button>
                    <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
                        <span class="caret"></span>
                        <span class="sr-only">Toggle Dropdown</span>
                    </button>
                    <ul id="dropPantStyle" class="dropdown-menu scrollable-menu" role="menu">
                    </ul>
                </div>
            </p>  
        </div>

最佳答案

在下面添加了一个快速示例,说明如何解决此问题。 Bootstrap 下拉菜单的使用非常具体,因此我使用的是 click 事件,而不是 change,后者是选择的正常事件。

$('#dropPants').on('click', 'li a', function() { ... });

此外,我没有添加任何数据属性,因为我没有您的解决方案的完整图片。但我希望你能用它来让事情按照你想要的方式进行。

您没有提供任何数据,因此我为品牌创建了一个数组,为样式创建了一个对象。每个品牌在包含样式数组的对象中都有一个属性

var pantsBrands = ['levis', 'lee', 'lindeberg'];
var pantsStyles = { 
        'levis': ['501','502'],
        'lee': ['bruce','kim'],
        'lindeberg': ['lindeberg1','lindeberg2']
};
<小时/>

无论如何,下面是一个 Bootstrap 下拉列表填充另一个下拉列表的工作示例:

var pantsBrands = ['levis','lee','lindeberg'];
var pantsStyles = { 'levis': ['501','502'],
                    'lee': ['bruce','kim'],
                    'lindeberg': ['lindeberg1','lindeberg2']
                  };

$.each(pantsBrands, function(i) {
  $('#dropPants').append('<li><a href="#">'+pantsBrands[i]+'</a></li>');
});

$('#dropPants').on('click', 'li a', function() {
  $('#dropPantStyle').html('');
  var showStyles = pantsStyles[$(this).text()];
  $.each(showStyles, function(i) {
    $('#dropPantStyle').append('<li><a href="#">'+showStyles[i]+'</a></li>');
  });   
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet" />
<div id='pantsLanding'>
  <p class="lead">Which brand of pants fits you best?</p>
  <p class="lead">
    <!-- Split button -->
    <div class="btn-group">
      <button type="button" class="btn btn-default">Brand</button>
      <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
        <span class="caret"></span>
        <span class="sr-only">Toggle Dropdown</span>
      </button>
      <ul id="dropPants" class="dropdown-menu scrollable-menu" role="menu">
      </ul>
    </div>
  </p>
</div>
<div id='pantStyleDiv'>
  <p class="lead">What style do you prefer?</p>
  <p class="lead">
    <!-- Split button -->
    <div class="btn-group">
      <button type="button" class="btn btn-default">Style</button>
      <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown" aria-expanded="false">
        <span class="caret"></span>
        <span class="sr-only">Toggle Dropdown</span>
      </button>
      <ul id="dropPantStyle" class="dropdown-menu scrollable-menu" role="menu">
      </ul>
    </div>
  </p>
</div>

关于javascript - 使用下拉列表选择填充第二个下拉列表内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30451385/

相关文章:

javascript - 无法读取 Node js中传入请求的数据

javascript - 通过 AJAX 刷新表格

javascript - 如何仅使用 CSS 制作图像轮播?

javascript - 使用 jQuery 根据另一个下拉列表中的选定选项显示隐藏的下拉列表

javascript - 使我的网站菜单触摸友好(下拉)

html - 如何让我的下拉菜单和悬停效果正确?

javascript - 页面更改后 Onclick 在面板中不起作用

javascript - 如何指定一个样式不被JS中指定的样式覆盖

javascript - ReactJS - TypeError : this. state.user.map 不是函数

javascript - 如何修复 Datatables 语言插件不工作?