jquery+php+mysql实现Ajax省市县三级联动
1、第一步建立一个html页面的,放置省、市、县三个select选择框,代码如下:
- <!DOCTYPE html>
- <html>
- <head>
- <title></title>
- <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
- <script src="./js/jquery-1.8.3.min.js" type="text/javascript"></script>
- <script type="text/javascript">
- $(document).ready(function() {
- // 加载所有的省份
- $.ajax({
- type: "get",
- url: "region_action.php", // type=1表示查询省份
- data: {"parent_id": "1", "type": "1"},
- dataType: "json",
- success: function(data) {
- $("#provinces").html("<option value=''>请选择省份</option>");
- $.each(data, function(i, item) {
- $("#provinces").append("<option value='" + item.region_id + "'>" + item.region_name + "</option>");
- });
- }
- });
- $("#provinces").change(function() {
- $.ajax({
- type: "get",
- url: "region_action.php", // type =2表示查询市
- data: {"parent_id": $(this).val(), "type": "2"},
- dataType: "json",
- success: function(data) {
- $("#citys").html("<option value=''>请选择市</option>");
- $.each(data, function(i, item) {
- $("#citys").append("<option value='" + item.region_id + "'>" + item.region_name + "</option>");
- });
- }
- });
- });
- $("#citys").change(function() {
- $.ajax({
- type: "get",
- url: "region_action.php", // type =2表示查询市
- data: {"parent_id": $(this).val(), "type": "3"},
- dataType: "json",
- success: function(data) {
- $("#countys").html("<option value=''>请选择县</option>");
- $.each(data, function(i, item) {
- $("#countys").append("<option value='" + item.region_id + "'>" + item.region_name + "</option>");
- });
- }
- });
- });
- });
- </script>
- </head>
- <body>
- <div>
- 省份:
- <select id="provinces">
- <option value="">请选择省份</option>
- </select>
- 市:
- <select id="citys">
- <option value="">请选择市</option>
- </select>
- 县:
- <select id="countys">
- <option value="">请选择县</option>
- </select>
- </div>
- </body>
- </html>
第二步:建立一个处理请求的PHP文件,如下:
- <?php
- require_once './Config/config.php';
- require_once './plugins/DBHelper.php';
- $type = isset($_GET["type"]) ? $_GET["type"] : "";
- $parent_id = isset($_GET["parent_id"]) ? $_GET["parent_id"] : "";
- // 链接数据库
- if ($type == "" || $parent_id == "") {
- exit(json_encode(array("flag" => false, "msg" => "查询类型错误")));
- } else {
- // 链接数据库
- $db = new DBHelper("localhost", "root", "root", "region");
- $provinces = $db->getSomeResult("global_region", "region_id,region_name", "parent_id={$parent_id} and region_type={$type}");
- $provinces_json = json_encode($provinces);
- exit($provinces_json);
- }
- ?>
第三步:其实这一步也是前提,就是要在mysql数据库中建一个地区表,此表结构简单,但是数据很多,大概3千多条,先列出表结构,具体数据请看代码附件。
- CREATE TABLE `global_region` (
- `region_id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
- `parent_id` smallint(5) unsigned NOT NULL DEFAULT '0',
- `region_name` varchar(120) NOT NULL DEFAULT '',
- `region_type` tinyint(1) NOT NULL DEFAULT '2',
- PRIMARY KEY (`region_id`),
- KEY `parent_id` (`parent_id`),
- KEY `region_type` (`region_type`)
- ) ENGINE=MyISAM AUTO_INCREMENT=3409 DEFAULT CHARSET=utf8;
最终结果如下:
jquery+php+mysql实现Ajax省市县三级联动的更多相关文章
- AJAX省市县三级联动的实现
省市县数据 本例子中省市县数据保存在MySQL数据库中,部分数据截图如下: 从数据库中读取数据 导入需要的jar包 连接池配置文件 <c3p0-config> <!-- 默认配置,如 ...
- AJAX省市县三级联动
效果 开发结构参考AJAX,JSON用户校验 主要有两个核心文件 1,处理输入字符,进行后台搜索的servlet linkage.java package org.guangsoft.servlet; ...
- 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框
JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP mysql数据库 SpringMvc ajax Controller层 Service层 中国地区 省 ...
- jQuery - 全国省市县三级联动
最近有空用jquery做了一个全国省市县的三级联动,在以后或许可以用的到 ,遗憾的是我还没用封装,等有空看能不能封装成一个插件 废话不多说,贴上代码: <!doctype html> &l ...
- 省市县三级联动 sql语句
发现在网上的省市县三级联动大部分是mysql的.就算是sqlserver的,也不准确.于是就把mysql的给改了下,适用sqlserver.sql语句如下: CREATE TABLE Dic_Area ...
- php仿经典省市县三级联动
之前有个需求要写个类似省市县三级联动的页面,于是,网上找了点资料看了下,其实原理很简单: 当我们选择一级栏目中某条记录的时候,会获取该栏目的vaule值,并发起ajax请求,后台根据这个vaule值, ...
- 基于Jquery实现省份、城市、区县三级联动
前端感觉写的比较少,也是为了练手,下午没事用来写了这个三级联动,也是第一次写这东西. 据我了解,城市信息可以选择存在数据库或者直接写在前端,为了省事,我直接写在前端,下面是我的代码: <!DOC ...
- wex5 实战 省市县三级联动与地址薄同步
无论是商城,还是快递,都要用到省市县三级联动,和地址薄,今天就以实战来制作,难点有3个: 1:三级联动,有wex5组件实现,相对简单,实战里对行数据进行了拼接 2: 地址薄选项,利用inputSel ...
- Android 省市县 三级联动(android-wheel的使用)[转]
转载:http://blog.csdn.net/lmj623565791/article/details/23382805 今天没事跟群里面侃大山,有个哥们说道Android Wheel这个控件,以为 ...
随机推荐
- HTTP历程
原文http://www.ruanyifeng.com/blog/2016/08/http.html 1.HTTP/0.9 HTTP是基于TCP/IP协议的应用层协议.它不涉及数据包传输,主要规定了客 ...
- 使用tomcat部署jsp程序
安装java1.6.0到默认目录 下载apache-tomcat-6.0.32-windows-x86.zip,解压到D:\soft目录下 配置环境变量 JAVA_HOME C:\Program Fi ...
- Binary Tree Zigzag Level Order Traversal [LeetCode]
Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...
- 1. Two Sum I & II & III
1. Given an array of integers, return indices of the two numbers such that they add up to a specific ...
- ios基础篇(二十三)—— 定时器NSTimer与图片的自动切换
一.NSTimer NSTimer是一个能在从现在开始到后面的某一个时刻或者周期性的执行我们指定的方法的对象.可以按照一定的时间间隔,将制定的信息发送给目标对象.并更新某个对象的行为.你可以选择在未来 ...
- EF6 CodeFirst+Repository+Ninject+MVC4+EasyUI实践(完)
前言 这一篇是本系列的最后一篇,虽然示例讲到这里就停止呢,但对于这些技术的学习远不能停止.虽然本示例讲的比较基础,但是正如我第一篇说到的,这个系列的目的不是说一些高端的架构设计,而是作为一个入门级,对 ...
- hibernate入门实例
1. 环境配置 1.1 hiberante环境配置 hibernate可实现面向对象的数据存储.hibernate的官网:http://hibernate.org/ 官网上选择hibernate OR ...
- IE下new Date不支持传参数的解决
在FF gloogle浏览器中 用js实例化Date对象时 各种参数都可以换传啊. var date = new Date("2014-10-1 10:24:31"); var d ...
- Ubuntu14.04使用apt-fast来加快apt-get下载的教程
代码如下: $ sudo add-apt-repository ppa:saiarcot895/myppa $ sudo apt-get update $ sudo apt-get install a ...
- 开启关闭keditor 过滤
filterMode: false, K.create('#txt_content', { uploadJson: '/js/kindeditor-4.1.10/upload_json.ashx', ...