PHP+Ajax+Mysql联合实现省市区三级联动

4 篇文章 0 订阅
2 篇文章 0 订阅

       1.mysql数据文件导入,该文件会上传到我的资源库  dh_areas

      2.HTML

   <select  id="province" name="province" οnchange="selcity(this.value,this.id)">
      <option value="">请选择</option>
          <volist name="province" id="vo" >
      <option  value="{$vo.area_id}">{$vo.area_name}</option>
          </volist>
   </select>
   <select  id="city" name="city" οnchange="selcity(this.value,this.id)">
      <option value="">请选择</option>
   </select>
   <select  id="country" name="country">
      <option value="">请选择</option>
   </select>
    3.ajax

  

var selcityUrl="__APP__/Home/RegisterInfo/getArea";
			function selcity(areaId,obgId){
				$.ajax({
					type:"post",
					url:selcityUrl,
					async:false,
					data:{
						"areaId":areaId
					},
					success:function(json){
						var json = eval('(' + json + ')');
						
						if(obgId=="province"){
							$("#city").empty();
						var optionObg="<option value=''>请选择</option>";
						for (var i=0;i<json.count;i++) {
							optionObg+="<option value='"+json[i].area_id+"'>"+json[i].area_name+"</option>";
						}
						$("#city").append(optionObg);
						}else{
							$("#country").empty();
						var optionObg="<option value=''>请选择</option>";
						for (var i=0;i<json.count;i++) {
							optionObg+="<option value='"+json[i].area_id+"'>"+json[i].area_name+"</option>";
						}
						$("#country").append(optionObg);
						}
						
					}
				});
			}
4.PHP

   (1)获取省列表

   

  public function register(){
     	  //获取省级地区
        $province=M('areas')->where(array('parent_id'=>1))->select();
        $this->assign('province',$province);
     	$this->display();
     }
   (2)获取市/县

public function getArea(){
        $where['parent_id']=I('areaId');
        $area=D('areas')->where($where)->select();
		$area['count']=count($area);
        $this->ajaxReturn($area,'json');
    }


     



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值