首页 » SEO优化 » php的联动技巧_运用PHPMySqlAjaxjQuery实现省市区三级联动功能

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

访客 2024-12-04 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

}

}

}

实现效果:

标签:

相关文章

今日头条算法岗三面算法工程师的面试之路

大数据和人工智能技术逐渐成为各行各业的热门话题。今日头条作为中国领先的资讯平台,其算法岗位一直是求职者争相竞逐的焦点。本文将针对今...

SEO优化 2025-01-31 阅读1 评论0

今日头条算法如何打造个化内容推荐

在移动互联网时代,信息爆炸已成为常态。如何在海量信息中找到自己感兴趣的内容,成为了一个亟待解决的问题。今日头条作为一款备受瞩目的新...

SEO优化 2025-01-31 阅读1 评论0

今日头条算法推荐其弊端与反思

算法推荐已经成为各大平台的核心竞争力。今日头条作为国内领先的资讯平台,凭借其强大的算法推荐系统,吸引了大量用户。在享受算法带来的便...

SEO优化 2025-01-31 阅读1 评论0

今日头条算法思维导图信息推荐的奥秘

信息传播速度越来越快,用户对信息的需求也越来越多样化。今日头条作为一款备受关注的新闻资讯平台,其背后的算法推荐机制一直是业界关注的...

SEO优化 2025-01-31 阅读1 评论0