我有两个联动的下拉框:第一个下拉框的每个选项会决定第二个下拉框中显示哪些选项。
第二个下拉框的选项被存储在一个二维数组中:
[ [{"id":1,"text":"a"}, {"id":2,"text":"b"},...],
[{"id":"1a","text":"aa"},{"id":"1b","text":"ba"},...],
...
]
第一个选择值确定用于填充第二个选择的索引。因此,在第一个选项上进行“更改”事件时,我应该能够修改包含在select-two中的项目。
阅读文档,我认为我需要使用“data”选项……但不确定如何操作,因为示例在初始化时加载数组数据,如果我尝试在初始化后执行相同操作似乎不起作用。
HTML
Attribute:
<select name="attribute" id="attribute">
<option value="0">Color</option>
<option value="1">Size</option>
</select>
Value:
<select name="value" id="value"></select>
<script>
var data = [ [{"id":1,"text":"black"}, {"id":2,"text":"blue"},...],
[{"id":"1","text":"9"},{"id":"1","text":"10"},...],
];
$('#attribute').select2().bind('change', function(){
// Here I need to change `#value` items.
$('#value').select2('data',data[$(this).val()]); // This does not work
);
$('#value').select2();
</script>