ホームページ ウェブフロントエンド jsチュートリアル jqueryとajaxで都道府県・市区町村のカプセル化・非カプセル化の3段階連携を実現

jqueryとajaxで都道府県・市区町村のカプセル化・非カプセル化の3段階連携を実現

Jan 12, 2018 am 09:26 AM
ajax jquery 州市地区

この記事では主に、カプセル化と非カプセル化の 2 つの方法を含む、地方と自治体の 3 レベルの連携を実現するための jquery+ajax の関連コードを詳しく紹介します。興味のある方は参考にしてください。皆さんのお役に立てれば幸いです。

まず、以下に示すような効果を実現するには、

1. 考えを明確にするために:

最初に 3 つのドロップダウン メニューを作成します -- 値に基づいて 2 番目のドロップダウン リストを取得します。最初のドロップダウン メニューの内容については、3 番目の内容にも同じことが当てはまります。

2. 使用されるデータベース テーブル: Chinastates テーブル

ルール: 国家レベル (中国) の市外局番に基づいて省レベル (北京など) をクエリします。 ) 地方の市外局番に基づいて ); 市区町村の市外局番に基づいて地区レベル (東城区など) をクエリします

最初の方法: カプセル化が使用されていないため、データの読み取りが遅くなります。原則として、2番目の方法でカプセル化するのが簡単になるためです。

コードは以下の通りです:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

<!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>  

ログイン後にコピー

期間中に発生した問題:各ドロップダウンリストの最初のデータの値にスペースが含まれているため、各ドロップダウンリストの最初のデータが出力できません! ! !したがって、データを出力するときはスペースを削除する必要があります。 ! !

data によって返される値にはスペースや改行などが含まれる場合があるため、trim() メソッドを使用してスペースを削除してください。 ! !

2 番目の方法: 将来いつでも呼び出すことができるプラグインにカプセル化します (重要)

(1) メイン ページ:


1

2

3

4

5

6

7

8

9

10

11

12

<!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) 独自のカプセル化js プラグイン


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

$(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);

 }

 });

}  

ログイン後にコピー

2 つ目はページの処理です (両方のメソッドで使用): chuli.php


1

2

3

4

5

6

7

<?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;

ログイン後にコピー

最後はカプセル化されたクラス ファイル: DB.class.php


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

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;

  }

}

?>

ログイン後にコピー

関連する推奨事項:

3レベル連携メニュー効果を実現するJquery、Ajax、xml

Ajax 3レベル連携実装方法

vue.jsを使用してJingdongの選択コンポーネントを模倣する省と市の三層連携

以上がjqueryとajaxで都道府県・市区町村のカプセル化・非カプセル化の3段階連携を実現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHP と Ajax: オートコンプリート提案エンジンの構築 PHP と Ajax: オートコンプリート提案エンジンの構築 Jun 02, 2024 pm 08:39 PM

PHP と Ajax を使用してオートコンプリート候補エンジンを構築します。 サーバー側スクリプト: Ajax リクエストを処理し、候補を返します (autocomplete.php)。クライアント スクリプト: Ajax リクエストを送信し、提案を表示します (autocomplete.js)。実際のケース: HTML ページにスクリプトを組み込み、検索入力要素の識別子を指定します。

jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? Feb 28, 2024 pm 03:12 PM

jQueryでPUTリクエストメソッドを使用するにはどうすればよいですか? jQuery で PUT リクエストを送信する方法は、他のタイプのリクエストを送信する方法と似ていますが、いくつかの詳細とパラメータ設定に注意する必要があります。 PUT リクエストは通常​​、データベース内のデータの更新やサーバー上のファイルの更新など、リソースを更新するために使用されます。以下は、jQuery の PUT リクエスト メソッドを使用した具体的なコード例です。まず、jQuery ライブラリ ファイルが含まれていることを確認してから、$.ajax({u

jQuery のヒント: ページ上のすべての a タグのテキストをすばやく変更する jQuery のヒント: ページ上のすべての a タグのテキストをすばやく変更する Feb 28, 2024 pm 09:06 PM

タイトル: jQuery ヒント: ページ上のすべての a タグのテキストをすばやく変更する Web 開発では、ページ上の要素を変更したり操作したりする必要がよくあります。 jQuery を使用する場合、ページ内のすべての a タグのテキスト コンテンツを一度に変更する必要がある場合があります。これにより、時間と労力を節約できます。以下では、jQuery を使用してページ上のすべての a タグのテキストをすばやく変更する方法と、具体的なコード例を紹介します。まず、jQuery ライブラリ ファイルを導入し、次のコードがページに導入されていることを確認する必要があります: &lt

jQuery を使用してすべての a タグのテキスト コンテンツを変更する jQuery を使用してすべての a タグのテキスト コンテンツを変更する Feb 28, 2024 pm 05:42 PM

タイトル: jQuery を使用して、すべての a タグのテキスト コンテンツを変更します。 jQuery は、DOM 操作を処理するために広く使用されている人気のある JavaScript ライブラリです。 Web 開発では、ページ上のリンク タグ (タグ) のテキスト コンテンツを変更する必要が生じることがよくあります。この記事では、この目標を達成するために jQuery を使用する方法を説明し、具体的なコード例を示します。まず、jQuery ライブラリをページに導入する必要があります。 HTML ファイルに次のコードを追加します。

Ajaxを使用してPHPメソッドから変数を取得するにはどうすればよいですか? Ajaxを使用してPHPメソッドから変数を取得するにはどうすればよいですか? Mar 09, 2024 pm 05:36 PM

Ajax を使用して PHP メソッドから変数を取得することは、Web 開発では一般的なシナリオであり、Ajax を使用すると、データを更新せずにページを動的に取得できます。この記事では、Ajax を使用して PHP メソッドから変数を取得する方法と、具体的なコード例を紹介します。まず、Ajax リクエストを処理し、必要な変数を返すための PHP ファイルを作成する必要があります。以下は、単純な PHP ファイル getData.php のサンプル コードです。

PHP と Ajax: 動的に読み込まれるコンテンツを作成するためのソリューション PHP と Ajax: 動的に読み込まれるコンテンツを作成するためのソリューション Jun 06, 2024 pm 01:12 PM

Ajax (非同期 JavaScript および XML) を使用すると、ページをリロードせずに動的コンテンツを追加できます。 PHP と Ajax を使用すると、製品リストを動的にロードできます。HTML はコンテナ要素を含むページを作成し、Ajax リクエストはロード後に要素にデータを追加します。 JavaScript は Ajax を使用して XMLHttpRequest を通じてサーバーにリクエストを送信し、サーバーから JSON 形式で商品データを取得します。 PHP は MySQL を使用してデータベースから製品データをクエリし、それを JSON 形式にエンコードします。 JavaScript は JSON データを解析し、ページ コンテナーに表示します。ボタンをクリックすると、製品リストをロードするための Ajax リクエストがトリガーされます。

jQuery における eq の役割と応用シナリオを理解する jQuery における eq の役割と応用シナリオを理解する Feb 28, 2024 pm 01:15 PM

jQuery は、Web ページでの DOM 操作やイベント処理を処理するために広く使用されている人気のある JavaScript ライブラリです。 jQueryではeq()メソッドを利用して指定したインデックス位置の要素を選択しますが、具体的な使い方と応用シーンは以下の通りです。 jQuery では、 eq() メソッドは、指定されたインデックス位置にある要素を選択します。インデックス位置は 0 からカウントされます。つまり、最初の要素のインデックスは 0、2 番目の要素のインデックスは 1 などとなります。 eq() メソッドの構文は次のとおりです。 $("s

jQueryを使用してテーブルに新しい行を追加する方法の紹介 jQueryを使用してテーブルに新しい行を追加する方法の紹介 Feb 29, 2024 am 08:12 AM

jQuery は、Web 開発で広く使用されている人気の JavaScript ライブラリです。 Web 開発中は、JavaScript を使用してテーブルに新しい行を動的に追加することが必要になることがよくあります。この記事では、jQuery を使用してテーブルに新しい行を追加する方法を紹介し、具体的なコード例を示します。まず、jQuery ライブラリを HTML ページに導入する必要があります。 jQuery ライブラリは、次のコードを通じてタグに導入できます。

See all articles