欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jquery+ajax實現(xiàn)省市區(qū)三級聯(lián)動(封裝和不封裝兩種方式)

 更新時間:2021年09月22日 15:53:08   作者:小魚小魚加油吐泡泡  
這篇文章主要為大家詳細介紹了jquery+ajax實現(xiàn)省市區(qū)三級聯(lián)動的相關代碼,包括封裝和不封裝兩種方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下

首先,要實現(xiàn)如下圖效果,

1、要理清思路:

先做出三個下拉菜單----根據(jù)第一個下拉菜單的value值獲取第二個下拉列表的內容,第三個同理。

2、用到的數(shù)據(jù)庫表:Chinastates表

規(guī)律:根據(jù)國家級(中國)的areacode查詢省級(如:北京) ; 根據(jù)省級的areacode查詢市級(如:北京市轄);根據(jù)市級的areacode查詢區(qū)級(如東城區(qū))

第一種方式:沒有用到封裝,數(shù)據(jù)讀取較慢,可以看看原理,這樣在第二種方式封裝時就容易多了。

代碼如下:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title></title>
 <script src="../jquery-1.11.2.min.js"></script>
 </head>
 <body>
 <select id="sheng"></select>
 <select id="shi"></select>
 <select id="qu"></select>
 </body>
</html>
<script type="text/javascript"> 
 $(document).ready(function(e){ 
 //輸出省
 var code = "0001";
 $.ajax({ 
  async:false,
  //取消異步
  url:"chuli.php",
  data:{code:code},
  type:"POST",
  dataType:"TEXT",
  success:function(data){    
   var hang = data.trim().split("|"); //trim()去空格
   var str=""; 
   for(var i=0;i<hang.length;i++)
   {
   var lie = hang[i].split("^");
   str = str+"<option value='"+lie[0]+"'>"+lie[1]+"</option>";
   }
   $("#sheng").html(str);  
  }   
 });
//輸出市
 $("#sheng").click(function(){ 
 var code2=$("#sheng").val(); 
 
 $.ajax({
  async:false,
  url:"chuli.php",
  data:{code:code2},
  type:"POST",
  dataType:"TEXT",
 success:function(data2){
 
  var hang2 = data2.trim().split("|");
 
  var str2 ="";
  for(var i=0;i<hang2.length;i++)
  {
   var lie2=hang2[i].split("^");
   str2 = str2 +"<option value ='"+lie2[0]+"'>"+lie2[1]+"</option>";
  }
  $("#shi").html(str2);
  }  
 }); 
 })
//輸出區(qū)縣
$("#shi").click(function(){
 var code3=$("#shi").val();
 
 $.ajax({
  async:false,
  url:"chuli.php",
  data:{code:code3},
  type:"POST",
  dataType:"TEXT",
  success:function(data3){
  var hang3 = data3.split("|");
  var str3 ="";
  for(var i=0;i<hang3.length;i++)
  {
   var lie3=hang3[i].split("^");
   str3 = str3 +"<option value ='"+lie3[0]+"'>"+lie3[1]+"</option>";
  }
  $("#qu").html(str3);
  }  
 });
 })
})
</script>  

期間出現(xiàn)的問題:每個下拉列表的第一個數(shù)據(jù)輸不出來:是因為每個下拉列表的第一個數(shù)據(jù)的value值都帶有空格?。。∷栽谳敵鰀ata時要去空格?。。?/p>

data返回的值可能帶有空格換行等,所以要用trim()方法去空格?。?!

第二種方式:封裝成插件,以后可以隨時調用(重要)

(1)主頁面:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title></title><br>//引入jquery包
 <script src="../jquery-1.11.2.min.js"></script><br>//引用我們自己封裝的js文件
 <script src="sanji.js"></script>
 </head>
 <body><br>//id要與封裝的js插件中一致
 <div id="sanji"></div>
 </body>
</html>

(2)我們自己封裝的js插件

$(document).ready(function(e){
 //扔三個下拉列表到主頁面建的div中
 $("#sanji").html("<select id='sheng'></select><select id='shi'></select><select id='qu'></select>"); 
 //加載省的數(shù)據(jù)
 LoadSheng();
 //加載市的數(shù)據(jù)
 LoadShi();
 //加載區(qū)的數(shù)據(jù)
 LoadQu();
 //給省的下拉列表添加點擊事件,當省變化時,對應的市和區(qū)會發(fā)生變化
 $("#sheng").click(function(){
 LoadShi();
 LoadQu();
 }) 
 //給市的下拉列表添加點擊事件,當市變化時,對應的區(qū)發(fā)生變化
 $("#shi").click(function(){
 LoadQu();
 })
 
});

//加載省的下拉列表
function LoadSheng() {
 var pcode = "0001";
 $.ajax({
 async: false,
 url: "chuli.php",
 data: { code: pcode },
 type: "POST",
 dataType: "TEXT",
 success: function(data) {
  var hang = data.trim().split("|");
  var str = "";
  for(var i = 0; i < hang.length; i++) {
  var lie = hang[i].split("^");
  str = str + "<option value='" + lie[0] + "'>" + lie[1] + "</option>";
  }
  $("#sheng").html(str);
 }
 });
}

//加載市省的下拉列表
function LoadShi() {
 var pcode = $("#sheng").val();
 $.ajax({
 async: false,
 url: "chuli.php",
 data: { code: pcode },
 type: "POST",
 dataType: "TEXT",
 success: function(data) {
  var hang = data.trim().split("|");
  var str = "";
  for(var i = 0; i < hang.length; i++) {
  var lie = hang[i].split("^");
  str = str + "<option value = '" + lie[0] + "'>" + lie[1] + "</option>";
  }
  $("#shi").html(str);
 }
 });
}

//加載省的下拉列表
function LoadQu() {
 var pcode = $("#shi").val();
 $.ajax({
 url: "chuli.php",
 data: { code: pcode },
 type: "POST",
 dataType: "TEXT",
 success: function(data) {
  var hang = data.trim().split("|");
  var str = "";
  for(var i = 0; i < hang.length; i++) {
  var lie = hang[i].split("^");
  str = str + "<option value = '" + lie[0] + "'>" + lie[1] + "</option>";
  }
  $("#qu").html(str);
 }
 });
}  

 其次就是處理頁面(兩種方法都用到的):chuli.php

<?php
$code=$_POST["code"];
require "DB.class.php";
$db=new DB();
$sql="select areacode,areaname from chinastates where parentareacode='{$code}'";
$str=$db->strquery($sql);
echo $str;

最后就是封裝的類文件:DB.class.php

function strquery($sql)
 {
 $db = new MySQLi($this->host,$this->uid,$this->pwd,$this->dbname);
 $result = $db ->query($sql);
 $arr =$result->fetch_all(); 
 $str="";
 foreach($arr as $v)
 {
 $str=$str.implode("^",$v)."|";
  }
 $str = substr($str,0,strlen($str)-1);
 return $str;
  }
}
?>

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

相關文章

  • jquery validator 插件增加日期比較方法

    jquery validator 插件增加日期比較方法

    jQuery plugin: Validation是一款功能強大的客戶端驗證插件,具有很多常用驗證方法,支持自定義驗證方法擴展、自定義語言包等等。
    2010-02-02
  • 表頭固定(利用jquery實現(xiàn)原理介紹)

    表頭固定(利用jquery實現(xiàn)原理介紹)

    表頭固定應該是一個用得比較多的功能,參考了網上幾個例子,在幾個常用瀏覽器下顯示不是很完美
    2012-11-11
  • jQuery中parentsUntil()方法用法實例

    jQuery中parentsUntil()方法用法實例

    這篇文章主要介紹了jQuery中parentsUntil()方法用法,實例分析了parentsUntil()方法的功能、定義及根據(jù)條件查找匹配元素的所有的祖先元素使用技巧,需要的朋友可以參考下
    2015-01-01
  • 基于Jquery的溫度計動畫效果

    基于Jquery的溫度計動畫效果

    將代碼一一拷貝到頁面相應的位置,然后記得調用jquery框架,展示條件有限,所以效果跟設計圖有出入,但實現(xiàn)原理是一樣的,歡迎大家多多交流!
    2010-06-06
  • jQuery模擬實現(xiàn)天貓購物車動畫效果實例代碼

    jQuery模擬實現(xiàn)天貓購物車動畫效果實例代碼

    最近在項目開發(fā)中遇到這樣的需求,點擊購買按鈕,模擬拋物線將物品彈到購物車里,購物車添加物品后,顯示+1動畫。效果非常棒,接下來小編把實例代碼分享到腳本之家平臺,需要的的朋友參考下吧
    2017-05-05
  • Jquery獲取當前城市的天氣信息

    Jquery獲取當前城市的天氣信息

    這篇文章主要為大家詳細介紹了Jquery獲取當前城市的天氣信息,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • jQuery的運行機制和設計理念分析

    jQuery的運行機制和設計理念分析

    jQuery是一個非常優(yōu)秀的JavaScript庫,與Prototype,YUI,Mootools等眾多的Js類庫相比,它劍走偏鋒,從Web開發(fā)實用的角度出發(fā),拋除了其它Lib中一些不實用的東西,為開發(fā)者提供了短小精悍的類庫。
    2011-04-04
  • jQuery contains過濾器實現(xiàn)精確匹配使用方法

    jQuery contains過濾器實現(xiàn)精確匹配使用方法

    contains 選擇器選取包含指定字符串的元素。該字符串可以是直接包含在元素中的文本,或者被包含于子元素中。經常與其他元素/選擇器一起使用,來選擇指定的組中包含指定文本的元素
    2013-04-04
  • jquery選擇器之屬性過濾選擇器詳解

    jquery選擇器之屬性過濾選擇器詳解

    本篇文章主要是對jquery選擇器之屬性過濾選擇器進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • JQuery中層次選擇器用法實例詳解

    JQuery中層次選擇器用法實例詳解

    這篇文章主要介紹了JQuery中層次選擇器用法,以實例形式較為詳細的分析了jQuery中層次選擇器的各種常見使用技巧,并備有較為詳細的注釋說明,需要的朋友可以參考下
    2015-05-05

最新評論