用JQuery和select来实现汽车厂商和汽车类型的联动,参考过程如下
效果图:
逻辑分析图:
html代码:
级联下拉框效果 汽车厂商: 汽车类型:
css代码:
.car {
text-align:center;
}
.cartype{
display:none;
}
js代码:
$(document).ready(function(){
//找到下拉框
var carnameSelect = $(".carname").children("select");
var cartypeSelect = $(".cartype").children("select");
//给下拉框注册事件
carnameSelect.change(function(){
var carnamevalue = $(this).val();
if( carnamevalue != ""){
//carnamevalue不为空的情况接着判断
if(!carnameSelect.data(carnamevalue)){
//不在缓冲区中,需要向服务器请求
$.post("ChainSelect",{keyword:carnamevalue,type:"top"},function(data){
if (data.length != 0){
//返回的数据不为空
cartypeSelect.html("");
$("").appendTo(cartypeSelect);
for(var i = 0;i < data.length; i++ ){
$("").appendTo(cartypeSelect);
}
cartypeSelect.parent().show();
carnameSelect.next().show();
}else{
//返回的数据为空
cartypeSelect.parent().hide();
carnameSelect.next().hide();
}
carnameSelect.data(carnamevalue,data);
},"json");
}else{
//在缓冲区中
var data = carnameSelect.data(carnamevalue);
if (data.length != 0){
//返回的数据不为空
cartypeSelect.html("");
$("").appendTo(cartypeSelect);
for(var i = 0;i < data.length; i++ ){
$("").appendTo(cartypeSelect);
}
cartypeSelect.parent().show();
carnameSelect.next().show();
}else{
//返回的数据为空
cartypeSelect.parent().hide();
carnameSelect.next().hide();
}
}
}else{
//carnamevalue为空的情况,隐藏第二个下拉框
cartypeSelect.parent().hide();
carnameSelect.next().hide();
}
});
});
如果大家还想深入学习,可以点击jquery下拉框效果汇总、Javascript下拉框效果汇总进行学习。
以上就是利用JQuery和select实现级联下拉框的小例子,希望对大家的学习有所帮助。



