三级地区级联筛选

//数据结构
region_id parent_id region_name region_type

//表单结构
<select name="province_id" id="province_id" class="input-small">
            <option value="">省</option>
          </select>
          <select name="city_id" id="city_id" class="input-small">
            <option>市</option>
          </select>
          <select name="area_id" id="area_id" class="input-small">
            <option>区</option>
</select>

 //js处理
<script>
/* 地区加载 */
var province_id=0;
var city_id=0;
var area_id=0;

var province=$('#province_id');
var city=$('#city_id');
var area=$('#area_id');
$('<option value="">请选择..</option>').appendTo(city);
$('<option value="">请选择..</option>').appendTo(area);
	
var loadRegion=function(parent_id,region_type,obj,callback){
	$.getJSON('<?php echo url('common/region');?>',
		{parent_id:parent_id,region_type:region_type},
		function(res){
			obj.empty();
			$('<option value="">请选择..</option>').appendTo(obj);
			for(var i=0;i<res.length;i++){
				$('<option value="'+res[i]['region_id']+'">'+res[i]['region_name']+'</option>').appendTo(obj);
			}
			if(callback){
				callback();
			}
		}
	);
}
province.change(function(){
	loadRegion($(this).val(),2,city,function(){
		loadRegion(city.val(),3,area);
	});
	

});
city.change(function(){
	loadRegion($(this).val(),3,area);

});

var province_callback=function(){
	if(province_id>0){
		province.val(province_id);
		loadRegion(province_id,2,city,function(){
			if(city_id>0){
				city.val(city_id);
				loadRegion(city_id,3,area,function(){
					area.val(area_id);
				});
			}
		});
	}
}
//初始化
loadRegion(1,1,province,province_callback);
</script>


转载于:https://my.oschina.net/sharesuiyue/blog/269145

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值