• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >AJAX > Ajax实现城市二级联动(一)

Ajax实现城市二级联动(一)

作者:九成 字体:[增加 减小] 来源:互联网 时间:2017-05-11

九成通过本文主要向大家介绍了Ajax实现城市二级联动(一)等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

前一篇是把省份和城市都写在JS里,这里把城市放在PHP里,通过发送Ajax请求城市数据渲染到页面。

1、html

<select id="province">
  <option>请选择</option>
  <option>山东省</option>
  <option>辽宁省</option>
  <option>吉林省</option>
 </select>
 <select id="city">
  <option>请选择</option>
 </select>
</div>

2、javascript

<script>
  /*
   * 需要思考哪些事情?
   * * 在什么时候执行Ajax的异步请求?
   *  * 当用户选择具体的省份信息时
   */
  // 1. 为id为province元素绑定onchange事件
  var provinceEle = document.getElementById("province");
  provinceEle.onchange = function(){
    // 清空
    var city = document.getElementById("city");
    var opts = city.getElementsByTagName("option");
    for(var z=opts.length-1;z>0;z--){
      city.removeChild(opts[z]);
    }
    
    if(provinceEle.value != "请选择"){
      // 2. 执行Ajax异步请求
      var xhr = getXhr();
      xhr.open("post","06.php");
      xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
      xhr.send("province="+provinceEle.value);
      xhr.onreadystatechange = function(){
        if(xhr.readyState==4&&xhr.status==200){
          // 接收服务器端的数据内容
          var data = xhr.responseText;
          // data是字符串,转换为数组
          var cities = data.split(",");
          for(var i=0;i<cities.length;i++){
            var option = document.createElement("option");
            var textNode = document.createTextNode(cities[i]);
            option.appendChild(textNode);
            city.appendChild(option);
          }
        }
      }
    }
    
  };
  // 定义获取ajax核心对象的函数XMLHttpRequest对象的函数
  function getXhr(){
    var xhr = null;
    if(window.XMLHttpRequest){
      xhr = new XMLHttpRequest();
    }else{
      xhr = new ActiveXObject("Microsoft.XMLHttp");
    }
    return xhr;
  }
 </script>
</div>

3、06.php

<?php
  // 用于处理客户端请求二级联动的数据
  // 1. 接收客户端发送的省份信息
  $province = $_POST['province'];
  // 2. 判断当前的省份信息,提供不同的城市信息
  switch ($province){
      case '山东省':
        echo '青岛市,济南市,威海市,日照市,德州市';
        break;
      case '辽宁省':
        echo '沈阳市,大连市,铁岭市,丹东市,锦州市';
        break;
      case '吉林省':
        echo '长春市,松原市,吉林市,通化市,四平市';
        break;
    }
  // 服务器端响应的是字符串
?>
</div>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

相关文章

  • 2017-05-11ajax获取php页面的返回参数,控件赋值的方法
  • 2017-05-11如何创建ajax对象并兼容多个浏览器
  • 2017-05-11使用加载图片解决在Ajax数据加载中页面出现短暂空白的问题(推荐)
  • 2017-05-11[js]一个获取页面ip的正则
  • 2017-05-11jQuery下的Ajax调试步骤
  • 2017-05-11使用jquery 的ajax调用总是错误亲测的解决方法
  • 2017-09-04Ajax加载中显示loading
  • 2017-05-11AJAX 常用函数创建XMLHTTP对象,区别IE,Mozilla浏览器
  • 2017-05-11AJAX打造博客无刷新搜索
  • 2017-05-11Ajax动态加载数据库示例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 使用ajax操作JavaScript 对象详解
    • ajax struts2 下拉框赋值(适合所有)
    • ajax实现三级联动的基本方法
    • ajax中data传参的两种方式分析
    • ajaxrequest.js ajaxrequest 0.7最新版 使用AJAXRequest进行AJAX应用程序开发入门小技巧
    • Ajax核心XMLHttpRequest总结
    • 浅析JSONP解决Ajax跨域访问问题的思路详解
    • 用juery的ajax方法调用aspx.cs页面中的webmethod方法示例
    • pushState实现Ajax无刷新页面切换
    • ajax实现session不过期(避免页面过期的现象)

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有