网络编程 
首页 > 网络编程 > 浏览文章

Ajax实现城市二级联动(三)

(编辑:jimmy 日期: 2024/9/24 浏览:3 次 )

本文实例为大家分享了Ajax实现城市二级联动的具体代码,供大家参考,具体内容如下

这是Ajax实现城市二级联动系列文章第三篇,把之前2篇整合在一起

1、html

<select id="province">
 <option>请选择</option>
 </select>
 <select id="city">
 <option>请选择</option>
 </select>

2、javascript

//创建获取ajax核心对象的函数
  function getXhr(){
   var xhr = null;
   if(window.XMLHttpRequest){
    xhr = new XMLHttpRequest();
   }else{
    xhr = new ActiveXObject("Microsoft.XMLHttp");
   }
   return xhr;
  }
  var xhr = getXhr();
  // 第一次执行Ajax异步请求 - 省份
  window.onload = function(){
   xhr.open("get","finaly.php");
   xhr.send(null);
   xhr.onreadystatechange = function(){
   if(xhr.readyState==4&&xhr.status==200){
     var data = xhr.responseText;
     // 将字符串转换为数组
     var provinces = data.split(",");
     // 遍历数组
     for(var i=0;i<provinces.length;i++){
      // 创建option元素添加到id为province元素上
      var option = document.createElement("option");
      var text = document.createTextNode(provinces[i]);
      option.appendChild(text);
      var province = document.getElementById("province");
      province.appendChild(option);
     }
    } 
   }
  };
  // 第二次执行Ajax异步请求 - 城市
  var province=document.getElementById("province");
  province.onchange = function(){
   var city = document.getElementById("city");
   var opts = city.getElementsByTagName("option");
   for(var z=opts.length-1;z>0;z--){
    city.removeChild(opts[z]);
   }
   if(province.value != "请选择"){
    xhr.open("post","finaly.php");
    xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
    xhr.send("state=2&province="+province.value);
    xhr.onreadystatechange = function(){
     if(xhr.readyState==4&&xhr.status==200){
      var data = xhr.responseText;
      var cities = data.split(",");
      for(var i=0;i<cities.length;i++){
       var option = document.createElement("option");
       var text = document.createTextNode(cities[i]);
       option.appendChild(text);
       city.appendChild(option);
      }
     }
    }
   }
  };

3、finaly.php

<?php
 // 接收客户端发送的请求数据 - state
 $state = $_REQUEST['state'];
 // 判断$state的值
 if($state == 1){// 获取省份
  echo '山东省,辽宁省,吉林省';
 }else{// 获取城市
  $province = $_POST['province'];
  switch ($province){
   case '山东省':
    echo '青岛市,济南市,威海市,日照市,德州市';
    break;
   case '辽宁省':
    echo '沈阳市,大连市,铁岭市,丹东市,锦州市';
    break;
   case '吉林省':
    echo '长春市,松原市,吉林市,通化市,四平市';
    break;
  }
 }
?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:AJAX跨域请求JSONP获取JSON数据的实例代码
下一篇:Ajax实现城市二级联动(二)
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 SiteMap