使用jQuery实现二级和三级联动,通常涉及到根据第一个下拉菜单的选择来动态更新第二个和第三个下拉菜单的选项。以下是一个简单的实现示例:
HTML部分:
<select id="first-select">
<option value="">请选择</option>
<option value="option1">选项1</option>
<option value="option2">选项2</option>
</select>
<select id="second-select">
<option value="">请选择</option>
</select>
<select id="third-select">
<option value="">请选择</option>
</select>
jQuery部分:
$(document).ready(function() {
var options1 = {
'option1': ['子选项1-1', '子选项1-2'],
'option2': ['子选项2-1', '子选项2-2']
};
var options2 = {
'子选项1-1': ['孙选项1-1-1', '孙选项1-1-2'],
'子选项2-1': ['孙选项2-1-1', '孙选项2-1-2']
};
$('#first-select').change(function() {
var firstValue = $(this).val();
var secondOptions = options1[firstValue] || [];
$('#second-select')
.empty()
.append($('<option>').text('请选择').attr('value', ''))
.append(secondOptions.map(function(option) {
return $('<option>').text(option).attr('value', option);
}));
var secondValue = $('#second-select').val();
var thirdOptions = options2[secondValue] || [];
$('#third-select')
.empty()
.append($('<option>').text('请选择').attr('value', ''))
.append(thirdOptions.map(function(option) {
return $('<option>').text(option).attr('value', option);
}));
}).change(); // 触发一次change事件以初始化第二个下拉菜单
});
在这个示例中,我们定义了两个对象options1
和options2
来表示不同级别的选项。当第一个下拉菜单的值改变时,通过jQuery的.change()
事件处理函数更新第二个下拉菜单的选项,然后基于第二个下拉菜单的值更新第三个下拉菜单的选项。.change()
事件处理函数还被初始化调用,以确保页面加载时正确设置下拉菜单。