主頁 > 知識庫 > Ajax實現(xiàn)城市二級聯(lián)動(三)

Ajax實現(xiàn)城市二級聯(lián)動(三)

熱門標簽:科大訊飛語音識別系統(tǒng) 電子圍欄 Mysql連接數(shù)設置 銀行業(yè)務 阿里云 Linux服務器 團購網(wǎng)站 服務器配置

本文實例為大家分享了Ajax實現(xiàn)城市二級聯(lián)動的具體代碼,供大家參考,具體內(nèi)容如下

這是Ajax實現(xiàn)城市二級聯(lián)動系列文章第三篇,把之前2篇整合在一起

1、html

select id="province">
 option>請選擇/option>
 /select>
 select id="city">
 option>請選擇/option>
 /select>

2、javascript

//創(chuàng)建獲取ajax核心對象的函數(shù)
  function getXhr(){
   var xhr = null;
   if(window.XMLHttpRequest){
    xhr = new XMLHttpRequest();
   }else{
    xhr = new ActiveXObject("Microsoft.XMLHttp");
   }
   return xhr;
  }
  var xhr = getXhr();
  // 第一次執(zhí)行Ajax異步請求 - 省份
  window.onload = function(){
   xhr.open("get","finaly.php?state=1");
   xhr.send(null);
   xhr.onreadystatechange = function(){
   if(xhr.readyState==4xhr.status==200){
     var data = xhr.responseText;
     // 將字符串轉(zhuǎn)換為數(shù)組
     var provinces = data.split(",");
     // 遍歷數(shù)組
     for(var i=0;iprovinces.length;i++){
      // 創(chuàng)建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);
     }
    } 
   }
  };
  // 第二次執(zhí)行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=2province="+province.value);
    xhr.onreadystatechange = function(){
     if(xhr.readyState==4xhr.status==200){
      var data = xhr.responseText;
      var cities = data.split(",");
      for(var i=0;icities.length;i++){
       var option = document.createElement("option");
       var text = document.createTextNode(cities[i]);
       option.appendChild(text);
       city.appendChild(option);
      }
     }
    }
   }
  };

3、finaly.php

?php
 // 接收客戶端發(fā)送的請求數(shù)據(jù) - state
 $state = $_REQUEST['state'];
 // 判斷$state的值
 if($state == 1){// 獲取省份
  echo '山東省,遼寧省,吉林省';
 }else{// 獲取城市
  $province = $_POST['province'];
  switch ($province){
   case '山東省':
    echo '青島市,濟南市,威海市,日照市,德州市';
    break;
   case '遼寧省':
    echo '沈陽市,大連市,鐵嶺市,丹東市,錦州市';
    break;
   case '吉林省':
    echo '長春市,松原市,吉林市,通化市,四平市';
    break;
  }
 }
?>

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Ajax結合php實現(xiàn)二級聯(lián)動
  • 幾種二級聯(lián)動案例(jQuery\Array\Ajax php)
  • Spring MVC中Ajax實現(xiàn)二級聯(lián)動的簡單實例
  • jQuery+JSON實現(xiàn)AJAX二級聯(lián)動實例分析
  • AJAX解析XML實例之下拉框省、市二級聯(lián)動
  • ajax讀取數(shù)據(jù)庫內(nèi)容實現(xiàn)二級聯(lián)動下拉選擇菜單示例
  • Ajax二級聯(lián)動菜單實現(xiàn)原理及代碼
  • asp.net下使用AjaxPro實現(xiàn)二級聯(lián)動代碼
  • 基于asp+ajax和數(shù)據(jù)庫驅(qū)動的二級聯(lián)動菜單
  • 一個強健 實用的asp+ajax二級聯(lián)動菜單(有演示和附源程序打包下載)

標簽:萍鄉(xiāng) 江蘇 棗莊 衢州 大理 蚌埠 廣元 衡水

巨人網(wǎng)絡通訊聲明:本文標題《Ajax實現(xiàn)城市二級聯(lián)動(三)》,本文關鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266