php用ajax方式实现四级联动

   使用ajax方式实现了下简单的 四级联动,

 数据库:

  

 

  以下为前台代码:

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4     <title>
  5         四级联动
  6     </title>
  7     <meta charset="utf-8">
  8     <script type="text/javascript" src = "jquery.min.js" ></script>
  9 
 10 </head>
 11 <body>
 12     
 13     <table border="1px" align="center" width="800px" >
 14         <form>
 15             <tr>
 16                 <th>国家</th><th></th><th></th><th></th>
 17             </tr>
 18             <tr>
 19                 <td>
 20                 <select  id = "guo">
 21                 </select>
 22                 </td>
 23                 <td>
 24                 <select  id = "sheng">
 25                 </select>
 26                 </td>
 27                 <td>
 28                 <select  id = "shi">
 29                 </select>
 30                 </td>
 31                 <td>
 32                 <select id = "xian">    
 33                 </select>
 34                 </td>
 35             </tr>
 36         </form>
 37     </table>
 38     
 39 </body>
 40 <script type="text/javascript">
 41 
 42     $(function(){
 43         //首先在加载时直接让第一栏展示一级类目
 44         $.ajax({
 45             'url':"liandong.php",
 46             'data':{pid:0},
 47             'type':"post",
 48             'dataType':"json",
 49             'success':function(data){
 50                 var result = data;
 51                 var str = "<option>请选择</option>";
 52                 //将接收到的数据遍历并拼接到字符串str中
 53                 $.each(result,function(index,value){
 54                     str+= "<option value="+value.id+">"+value.area+"</option>";
 55 
 56                 });
 57                 //将字符串str添加到select中
 58                 $('#guo').html(str);    
 59             }
 60         });
 61 
 62         //当一级栏目发生变更,触发change事件
 63         $('#guo').change(function(){
 64             var a = $('#guo option:selected').attr("value");
 65 
 66             $.ajax({
 67                 'url':"liandong.php",
 68                 'data':{pid:a},
 69                 'type':"post",
 70                 'dataType':"json",
 71                 'success':function(data2){
 72                     var result2 = data2;
 73                     var str2 = "<option>请选择</option>";
 74                     $.each(result2,function(i,v){
 75                         str2 += "<option value="+v.id+">"+v.area+"</option>";
 76 
 77                     });
 78 
 79                     $('#sheng').html(str2);    
 80                 }
 81             });
 82         });
 83         
 84         $('#sheng').change(function(){
 85             var b = $('#sheng option:selected').attr("value");
 86 
 87             $.ajax({
 88                 'url':"liandong.php",
 89                 'data':{pid:b},
 90                 'type':"post",
 91                 'dataType':"json",
 92                 'success':function(data3){
 93                     var result3 = data3;
 94                     var str3 = "<option>请选择</option>";
 95                     $.each(result3,function(i,v){
 96                         
 97                         str3 += "<option value="+v.id+">"+v.area+"</option>";
 98 
 99                     });
100 
101                     $('#shi').html(str3);    
102                 }
103             });
104         });
105 
106         $('#shi').change(function(){
107             var c = $('#shi option:selected').attr("value");
108 
109             $.ajax({
110                 'url':"liandong.php",
111                 'data':{pid:c},
112                 'type':"post",
113                 'dataType':"json",
114                 'success':function(data4){
115                     var result4 = data4;
116                     var str4 = "<option>请选择</option>";
117                     $.each(result4,function(i,v){
118                         str4 += "<option value="+v.id+">"+v.area+"</option>";
119 
120                     });
121 
122                     $('#xian').html(str4);    
123                 }
124             });
125         });
126     });
127     
128     
129 
130 </script>
131 
132 </html>

php代码:

 1 header('content-type:text/html;charset=utf-8');
 2 
 3 function mysql_get($sql){
 4 
 5     //连接数据库
 6     $mysql = mysqli_connect("localhost","root","root","lx");
 7 
 8     //执行sql语句
 9     $result = mysqli_query($mysql,$sql);
10     //定义空数组
11     $data = array();
12 
13     //从结果集中取出数据存入data中
14     while($row = mysqli_fetch_array($result,MYSQLI_ASSOC)){
15     $data[] = $row;
16     }
17 
18     return $data;
19 }
20 
21 //接收pid
22 $pid = $_POST['pid'];
23 
24 $sql = "select * from sp_area where pid = $pid";
25 //调用自定义的mysql_get函数
26 $data = mysql_get($sql);
27 
28 //echo 到前台页面
29 echo json_encode($data);
30 

 

转载于:https://www.cnblogs.com/liyante/p/7820265.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/415345.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OI回忆录——一个过气OIer的制杖历程

初中 初一参加学校信息学选修课&#xff0c;一周一节课&#xff0c;学pascal。  初一寒假&#xff08;大约是&#xff09;入选&#xff08;其实是钦定吧&#xff09;当时加上我只有3人的校队&#xff08;我当然是最弱的一个。  当时甚至有幸得到叉姐授课&#xff08;现在才…

工作157:动态路由

第一步 route里面加一个 第二步跳转

前端学习(2644):懂代码之header表头页之折叠功能

第一步 header.vue <!-- 折叠按钮 --><div class"collapse-btn" click"collapseChage"><i v-if"!collapse" class"el-icon-s-fold"></i><i v-else class"el-icon-s-unfold"></i></d…

简单使用CXF实现webserver(rs的独立发布)

简单使用cxf_rs的方式实现webserver 1创建maven project java项目 2,在maven文件中导入相关依赖 <dependencies>    <!--使用 CXF 的RS开发模式 --><dependency><groupId>org.apache.cxf</groupId><artifactId>cxf-rt-frontend-jaxrs&…

工作158:vue里面为什么要加key

没有key <div id"app"><div><input type"text" v-model"name"><button click"add">添加</button></div><ul><li v-for"(item, i) in list"><input type"checkbox&…

Android 人脸识别拍照demo

1、活体与照片。效果&#xff0c;捕获人脸 2、活体人脸识别&#xff1a;https://blog.csdn.net/meixi_android/article/details/88690445 运行效果&#xff1a; 自定义获取人脸view /*** 作者&#xff1a;created by meixi* 邮箱&#xff1a;13164716840163.com* 日期&#x…

多进程进阶

一 multiprocessing模块介绍 python中的多线程无法利用多核优势&#xff0c;如果想要充分地使用多核CPU的资源&#xff08;os.cpu_count()查看&#xff09;&#xff0c;在python中大部分情况需要使用多进程。Python提供了multiprocessing。 multiprocessing模块用来开启子进…

typescript 安装

记录基本的typescript 安装过程。 1、安装 查看最新的版本号 npm show typescript去npm服务器读取包最新的信息&#xff1a; npm install -g typescript使用tsc -v查看版本号 使用npm bin -g查看安装目录 2、使用tsc index.ts就可以将ts文件编译成js文件。 官方在线实练…

linux中修改字符编码

一. ubuntu修改字符编码 1. 添加字符编码&#xff0c;例如zh_CN.UTF-8&#xff0c;有两种方式 方法1&#xff1a;locale-gen zh_CN.UTF-8 #locale-gen命令只在ubuntu中才有 方法2&#xff1a;在/var/lib/locales/supported.d/local中添加字符集zh_CN.UTF-8&#xff0c;保存后…

iview代码片段 去除水平menu底部横线

此处记录日常写的小代码片段 直接使用iview的Menu在底部会出现一条border线&#xff0c;而我的使用场景&#xff0c;不需要border线。所以我就覆盖一下它原来的样式&#xff0c;就可以了。 代码&#xff1a; .ivu-menu-light {&:after {height: 0px !important;}}效果&a…

工作161:eachart渲染步骤

第一步 页面 第二步 第三步 方法调用

vue js xlsx 读取 本地 excel

最近在写一个人力资源管理系统&#xff0c;主要目的是将本地的excel文件读取解析&#xff0c;将有效数据传到后台。 下文介绍流程&#xff0c;文末附有参考文章。 1、安装npm包xlsx yarn add xlsx2、结合上传组件和自己写的读取方法readXLSX&#xff0c;可以进行本地excel读…

工作163:eachrt修改

<template><div><el-card><el-card><time-selects GetTime"GetTime"></time-selects><!--第一步 页面--><div id"main" :style"{ width: 1000px, height: 300px }"></div><div id&quo…

Android 使用ViewPager实现view轮播效果,单个item分页样式,多个item分页样式,横向listview

效果 单个item样式 多个item样式 横向item 自定义viewpager——可开关切换动画 public class NoAnimationViewPager extends ViewPager {public NoAnimationViewPager(Context context) {super(context);}public NoAnimationViewPager(Context context, AttributeSet attrs) …

工作164:对父和混入的理解

1点击按钮看编辑事件 2点击编辑之后 对当前页面的方法进行调用 3找到子组件下面的混入方法 create下面引入混入 4找到子组件混入下面的混入方法 5找到下面的getlist方法

工作165:混入调用的时候

直接created里面定义 不需要在其他位置进行过多操作

工作166:错误的处理方式

1这种处理没有数据 2 这样处理勉强调用了接口 但是获取数据还是有问题

07异常处理

1、 【请尝试解释以下奇怪的现象&#xff01;】 int i1, j0, k; ki/j; 代码在运行时会引发异常 上边代码在运行时不会引发异常 浮点数除以0&#xff1a;Infinity 可以使用javap去反汇编两个示例程序的.class文件&#xff08;一个是AboutException.class&#xff0c;另一个是Thr…

工作166:正确eachrt渲染方式

1第一步 2第二步 3第三步