Maison  >  Article  >  interface Web  >  jquery et ajax réalisent l'encapsulation et la non-encapsulation de liaison à trois niveaux des provinces et des municipalités

jquery et ajax réalisent l'encapsulation et la non-encapsulation de liaison à trois niveaux des provinces et des municipalités

小云云
小云云original
2018-01-12 09:26:302199parcourir

Cet article présente principalement en détail le code pertinent de jquery+ajax pour réaliser la liaison à trois niveaux des provinces et des municipalités, y compris deux méthodes d'encapsulation et de non-encapsulation, qui a une certaine valeur de référence. Les amis intéressés peuvent s'y référer. . J'espère pouvoir aider tout le monde.

Tout d'abord, pour obtenir l'effet indiqué ci-dessous,

1 Pour clarifier vos idées :

Faites d'abord trois gouttes. -down menus - ---Obtenez le contenu de la deuxième liste déroulante en fonction de la valeur du premier menu déroulant, et il en va de même pour la troisième.

2. Table de base de données utilisée : table Chinastates

Règle : Interrogez le niveau provincial (comme Pékin) en fonction de l'indicatif régional du niveau national (Chine ); Interrogez le niveau municipal (tel que la municipalité de Pékin) en fonction de l'indicatif régional provincial ; interrogez le niveau du district (tel que le district de Dongcheng) en fonction de l'indicatif régional municipal

La première méthode : n'utilise pas l'encapsulation , la lecture des données est lente, vous pouvez jeter un œil au principe, ce qui facilitera grandement l'encapsulation dans la deuxième manière.

Le code est le suivant :


<!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=&#39;"+lie[0]+"&#39;>"+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 =&#39;"+lie2[0]+"&#39;>"+lie2[1]+"</option>";
  }
  $("#shi").html(str2);
  }  
 }); 
 })
//输出区县
$("#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 =&#39;"+lie3[0]+"&#39;>"+lie3[1]+"</option>";
  }
  $("#qu").html(str3);
  }  
 });
 })
})
</script>  

Problèmes survenus pendant la période : Les premières données de chaque liste déroulante ne peuvent pas être affiché : parce que la valeur de la première donnée dans chaque liste déroulante contient des espaces ! ! ! Il n'y a donc pas d'espace lors de la sortie des données ! ! !

La valeur renvoyée par data peut contenir des espaces, des sauts de ligne, etc., utilisez donc la méthode trim() pour supprimer les espaces ! ! !

Deuxième méthode : Encapsulé dans un plug-in, qui peut être appelé à tout moment dans le futur (important)

(1) Page principale :


<!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插件中一致
 <p id="sanji"></p>
 </body>
</html>

(2) Notre propre plug-in js encapsulé


$(document).ready(function(e){
 //扔三个下拉列表到主页面建的p中
 $("#sanji").html("<select id=&#39;sheng&#39;></select><select id=&#39;shi&#39;></select><select id=&#39;qu&#39;></select>"); 
 //加载省的数据
 LoadSheng();
 //加载市的数据
 LoadShi();
 //加载区的数据
 LoadQu();
 //给省的下拉列表添加点击事件,当省变化时,对应的市和区会发生变化
 $("#sheng").click(function(){
 LoadShi();
 LoadQu();
 }) 
 //给市的下拉列表添加点击事件,当市变化时,对应的区发生变化
 $("#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=&#39;" + lie[0] + "&#39;>" + 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 = &#39;" + lie[0] + "&#39;>" + 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 = &#39;" + lie[0] + "&#39;>" + lie[1] + "</option>";
  }
  $("#qu").html(str);
 }
 });
}  

La deuxième étape est pour traiter la page (les deux méthodes sont utilisées) : chuli.php


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

Le dernier est le fichier de classe encapsulé : 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;
  }
}
?>

Recommandations associées :

Jquery, Ajax, XML pour réaliser l'effet de menu de liaison à trois niveaux

Méthode de mise en œuvre du lien à trois niveaux Ajax

Utilisez vue.js pour imiter le composant de sélection du lien à trois niveaux de JD.com entre les provinces et les villes

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn