首页 » PHP教程 » php获取省市联动技巧_运用PHPMySqlAjaxjQuery实现省市区三级联动功能

php获取省市联动技巧_运用PHPMySqlAjaxjQuery实现省市区三级联动功能

访客 2024-11-21 0

扫一扫用手机浏览

文章目录 [+]

实现技能:php ajax

实现:省级下拉变革时市下拉区下拉随着变革,市级下拉变革时区下拉随着变革。

php获取省市联动技巧_运用PHPMySqlAjaxjQuery实现省市区三级联动功能

利用chinastates表查询

php获取省市联动技巧_运用PHPMySqlAjaxjQuery实现省市区三级联动功能
(图片来自网络侵删)

Ajax加载数据

1.这是chinastates表

2.做一个大略php:Ajax_eg.php

<!DOCTYPE html>

<html>

<head>

<meta charset=\"大众UTF-8\"大众>

<title></title>

<script src=\"大众bootstrap/js/jquery-1.11.2.min.js\"大众></script>

</head>

<style>

.sanji{

margin-left: 550px;

margin-top: 150px;

}

</style>

<body>

<div class=\公众sanji\"大众> </div>

</body>

</html>

3.根据前一个页面做jquery:Ajax_ssq.js

// JavaScript Document

//当页面内容都加载完才实行

$(document).ready(function(e) {

//加载三个下拉列表

$(\"大众#sanji\公众).html(\"大众<select id='sheng'></select><select id='shi'></select><select id='qu'></select>\"大众);

//加载显示数据

//1.加载省份

LoadSheng();

//2.加载市

LoadShi();

//3.加载区

LoadQu();

//当省份选中变革,重新加载市和区

$(\"大众#sheng\公众).change(function(){ //当元素的值发生改变时,会发生 change 事宜,该事宜仅适用于文本域(text field),以及 textarea 和 select 元素。

//加载市

LoadShi();

//加载区

LoadQu();

})

//当市选中变革,重新加载区

$(\公众#shi\"大众).change(function(){

//加载区

LoadQu();

})

});

//加载省份信息

function LoadSheng()

{

//取父级代号

var pcode =\"大众0001\公众;

//根据父级代号查数据

$.ajax({

//取消异步,也便是必须完成上面才能走下面

async:false,

url:\公众load.php\"大众,

data:{pcode:pcode},

type:\公众POST\"大众,

dataType:\"大众JSON\"大众,

success: function(data){

var str=\"大众\"大众;

//遍历数组,把它放入sj

for(var k in data){

str=str+\"大众<option value='\"大众+data[k].[0]+\公众'>\公众+data[k].[1]+\"大众</option>\"大众;

}

$(\公众#sheng\"大众).html(str);

}

});

}

//加载市信息

function LoadShi()

{

//取父级代号

var pcode =$(\"大众#sheng\"大众).val();

//根据父级代号查数据

$.ajax({

//取消异步,也便是必须完成上面才能走下面

async:false,

url:\"大众load.php\"大众,

data:{pcode:pcode},

type:\"大众POST\公众,

dataType:\公众JSON\公众,

success: function(data){

var str=\公众\公众;

//遍历数组,把它放入sj

for(var k in data){

str=str+\"大众<option value='\"大众+data[k].[0]+\"大众'>\"大众+data[k].[0]+\公众</option>\公众;

}

$(\"大众#shi\"大众).html(str);

}

});

}

//加载区信息

function LoadQu()

{

//取父级代号

var pcode =$(\"大众#shi\"大众).val();

//根据父级代号查数据

$.ajax({

//不须要取消异步

url:\"大众load.php\"大众,

data:{pcode:pcode},

type:\"大众POST\"大众,

dataType:\"大众JSON\公众,

success: function(data){

var str=\公众\公众;

//遍历数组,把它放入sj

for(var k in data){

str=str+\公众<option value='\"大众+data[k].[0]+\公众'>\"大众+data[k].[1]+\"大众</option>\"大众;

}

$(\公众#qu\公众).html(str);

}

});

}

4.再把数据库连接起来 :load.php,把DBDA重新加载一个方法:JsonQuery

<?php

$pcode = $_POST[\"大众pcode\"大众];

require_once \"大众./DBDA.class.php\"大众;

$db = new DBDA();

$sql = \公众select from chinastates where parentareacode='{$pcode}'\"大众;

echo $db->JsonQuery($sql,0);

封装类

<?php

class DBDA{

public $host=\公众localhost\"大众;

public $uid=\公众root\"大众;

public $pwd=\"大众\"大众;

public $dbname=\"大众0710_info\"大众;

/

query方法:实行用户给的sql语句,并返回相应的结果

$sql:用户须要实行的sql语句

$type:用户须要实行的sql语句的类型

return:如果是增删语句改返回true或false,如果是查询语句返回二维数组

/

public function query($sql,$type=1){//默认true为增编削

$db = new MySQLi($this->host,$this->uid,$this->pwd,$this->dbname);

if(mysqli_connect_error()){

return \"大众连接失落败!\"大众;

}

$result = $db->query($sql);

if($type==1){

return $result;//增编削语句返回true或false

}else{

return $result->fetch_all();//查询语句返回二维数组

}

}

//此方法用于ajax中用于对取出的数据(二维数组)进行拼接字符串处理

public function StrQuery($sql,$type=1){

$db = new MySQLi($this->host,$this->uid,$this->pwd,$this->dbname);

if(mysqli_connect_error()){

return \"大众连接失落败!\"大众;

}

$result = $db->query($sql);

if($type==1){

return $result;//增编削语句返回true或false

}else{

$arr = $result->fetch_all();//查询语句返回二维数组

$str = \"大众\公众;

foreach($arr as $v){

$str = $str.implode(\"大众^\"大众, $v).\公众|\"大众;

}

$str = substr($str, 0,strlen($str)-1);

return $str;

}

}

//此方法用于ajax中用于返回为json数据类型时利用

public function JsonQuery($sql,$type=1){

$db = new MySQLi($this->host,$this->uid,$this->pwd,$this->dbname);

if(mysqli_connect_error()){

return \公众连接失落败!\公众;

}

$result = $db->query($sql);

if($type==1){

return $result;//增编削语句返回true或false

}else{

$arr = $result->fetch_all();//查询语句返回二维(关联)数组

return json_encode($arr);//将数组转换成json

}

}

}

实现效果:

标签:

相关文章

动态介绍语言,推动编程变革的引擎

随着互联网技术的飞速发展,编程语言作为软件开发的基石,其重要性日益凸显。动态解析语言作为一种新兴的编程语言,凭借其独特的优势,正在...

PHP教程 2024-12-27 阅读0 评论0

最强IT求职攻略,迈向未来的职业之路

随着科技的发展,信息技术(IT)行业已成为我国乃至全球最具活力和潜力的行业之一。在这个时代背景下,越来越多的人选择投身IT行业,寻...

PHP教程 2024-12-27 阅读0 评论0

构建合理IT架构,企业数字化转型之基石

随着信息技术的飞速发展,企业数字化转型已成为当今时代的主流趋势。在这样一个信息化、智能化的时代,如何构建合理的IT架构,成为企业实...

PHP教程 2024-12-27 阅读0 评论0

构建未来IT网络框架,关键要素与实施步骤

随着信息技术的飞速发展,网络已成为企业和社会运行的重要基础设施。构建一个高效、安全、可靠的IT网络框架,已成为企业信息化建设的关键...

PHP教程 2024-12-27 阅读0 评论0