关于Ajax

1.干什么的?

ajax负责抓取用户名信息,传递给服务器进行校验;

2.属性:
  onreadystatechange:事件,该事件可以感知ajax状态(readyState)的变化。ajax请求过程中要随时感知其状态  

  readyState:表示ajax状态值

     ajax有5种状态readyState:
          0------> 创建ajax对象完毕
          1------> 有调用open()方法
          2------> 有调用send()方法
          3------> 服务器端数据只返回了一部分
          4------> 服务器端数据全部返回,ajax请求完成

  responseText:以字符串形式接收服务器端返回的信息

3.方法:
       open():创建一个新的http请求

send():发送请求到服务器

  例如:

    get:$xhr.open("get","123.php?a=1&b=2");$xhr.send(null);  //如果方式为get,则send为null

    post:$xhr.open("post","123.php);post方法的对应的send:

    //(要在open()方法执行之后设置)

    xhr.setRequestHeader('content-type','application/x-www-form-urlencoded');

    var info = "name=abc&age=20";

    xhr.send(info);

 4.同步异步:

async:true/false,

true(默认):异步。同时可进行多个操作。

false:同步。同一时间只能进行一个操作。

5.页面跳转

ajax不能从php页面直接进行跳转,只是返回一个数据。要想跳转页面要从js跳转。

 <!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>三级联动</title>
</head> <body>
省:<select name="" id="sheng" onChange="selshi(this)">
<option value="">请选择</option>
</select>
市:<select name="" id="shi" onChange="selqu(this)">
<option value="">请选择</option>
</select>
区:<select name="" id="qu">
<option value="">请选择</option>
</select>
</body>
</html>
<script>
var attr = [];
//页面加载完成显示省的内容
window.onload = function(){
//发起请求
sendInfo("sheng");
}
function sendInfo(type,code=0){
//创建对象
var xhr = new XMLHttpRequest();
//监听ajax状态
//responseText(返回值)
xhr.onreadystatechange = function(){
if(xhr.readyState == 4){
//处理数据
chuliData(xhr.responseText,type); }
}
//创建请求
xhr.open("get","conn_db.php?type="+type+"&code="+code);
//发送请求
xhr.send(null);
}
function chuliData(data,type){
//将字符串转为二维字符数组arr:1,山东;3,河北;
var arr = data.split(";");
var str = '';
for(var i = 0; i < arr.length; i++){
//拆分二维数组为:1,山东
attr[i] = arr[i].split(",");
//option的value = 1,内容 = 山东
str += '<option value="'+attr[i][0]+'">'+attr[i][1]+'</option>';
}
console.log(str);
document.getElementById(type).innerHTML = str;
}
function selshi(obj){
sendInfo('shi',obj.value);
}
function selqu(obj){
sendInfo('qu',obj.value);
}
</script>

三级联动示例:html+js部分

 <?php
//链接数据库
$db = new mysqli('localhost','root','123456','sjld');
//判断链接是否成功
!mysqli_connect_error() or die("连接失败");
//设置字符编码
$db->query("set names utf8"); $sql = "";
$str = "";
//获取code(上级id)
$get_code = $_GET['code'];
//根据$get_code查询出相关数据
$sql = "select id,area_name from dt_area where pid = $get_code";
$res = $db->query($sql);
$arr = $res->fetch_all();
//处理二维数组$arr,先转为字符串
foreach($arr as $v){
foreach($v as $vv){
$str .= $vv.",";
}
//去掉最后一个逗号
$str = substr($str,0,-1);
//一组结束,用;分隔
$str .= ";";
}
//去掉最后一个分号
$str = substr($str,0,-1);
echo $str;

三级联动示例:php部分

0509 关于Ajax + 三级联动示例的更多相关文章

  1. ajax验证表单元素规范正确与否 ajax展示加载数据库数据 ajax三级联动

    一.ajax验证表单元素规范正确与否 以用ajax来验证用户名是否被占用为例 1创建表单元素<input type="text" id="t"> 2 ...

  2. 使用 AJAX + 三级联动 实现分类出全国各地的省,市,区

    使用AJAX + 三级联动  实现分类出全国各地的省,市,区 也可以将下面的显示页面所写的 function循环,封装成js文件,就是在写代码软件里创建一个js文件,就和创建一个HTML或php文件一 ...

  3. AJAX 三级联动

    新的封装类 <?php class DBDA { public $host="localhost";//服务器地址 public $uid="root"; ...

  4. ajax三级联动下拉菜单

    ajax写三级联动,先写一个文件类吧,以后用的时候直接调用即可: 来找一张表: 实现: 中国地域的三级联动:省.市.区: 图: 说一下思路: (1)当用户选择省份的时候触发事件,把当前的省份的id通过 ...

  5. [Ajax三级联动 无刷新]

    三级联动 的效果图 html页面: <body> <label class="fl">区域:</label> <select class= ...

  6. 2019.03.25 Ajax三级联动

    所谓三级联动就是,一层接着一层,根据上一层的选择给出这一层的结果 如选择市之后,会给出相应的区,然后到相应的县这就是联动 配置视图 ​from django.core import serialize ...

  7. ajax 三级联动商品分类(转载)

    转载  自  jines     http://www.cnblogs.com/lijinblogs/p/5759399.html 思路分析:效果:当页面加载时,利用ajax异步向后台请求数据,加载一 ...

  8. Ajax三级联动

    全国省市县查询 html代码 <!doctype html> <html> <head> <meta charset="utf-8"> ...

  9. 原生javascript AJAX 三级联动

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. linux杀掉某个进程的脚本

    https://www.cnblogs.com/zeng1994/p/13a2c5a28e55dd3abc2c75a4fb80371a.html awk的说明: https://www.cnblogs ...

  2. ubuntu下sudo命令不能使用问题

    不知道从什么时候开始,ctrl+alt+F1进入命令行之后,登录成功.使用sudo命令,不能使用....被坑了很久. 解决方法: 出现 [sudo ] username !!! 之后,在输入一遍 密码 ...

  3. 【技术累积】【点】【java】【21】序列化二三事

    基础概念 把对象等转为二进制进行传输的是序列化,反之为反序列化: 应用场景一般为读写文件,传输数据/接口调用: Externalizable和Serializable java的序列化方式有两种: S ...

  4. vue02 过滤器、计算和侦听属性、vue对象的生命周期、阻止事件冒泡和刷新页面

    3. Vue对象提供的属性功能 3.1 过滤器 过滤器,就是vue允许开发者自定义的文本格式化函数,可以使用在两个地方:输出内容和操作数据中. 定义过滤器的方式有两种. 3.1.1 使用Vue.fil ...

  5. 10.3 io流 正篇 FileReader FileWriter读写代码

    一.FileWriter 小节: 1)FileWriter fw = new FileWriter("a.txt",true);//表示追加写入,默认是false.正常情况:执行多 ...

  6. 1 JSONP

    一.什么是跨域访问举个栗子:在A网站中,我们希望使用Ajax来获得B网站中的特定内容.如果A网站与B网站不在同一个域中,那么就出现了跨域访问问题.你可以理解为两个域名之间不能跨过域名来发送请求或者请求 ...

  7. 爬虫之cookie

    什么是cookie: 在网站中,http请求是无状态的.也就是说即使第一次和服务器连接后并且登录成功后,第二次请求服务器依然不能知道当前请求是哪个用户.cookie的出现就是为了解决这个问题,第一次登 ...

  8. 洛谷——P1759 通天之潜水

    P1759 通天之潜水   题目背景 直达通天路·小A历险记第三篇 题目描述 在猴王的帮助下,小A终于走出了这篇荒山,却发现一条波涛汹涌的河拦在了自己的面前.河面上并没有船,但好在小A有n个潜水工具. ...

  9. 39.date hitogram基础知识

    主要知识点: date hitogram之统计每月电视销量     上一节讲到histogram,他是以数值进行分组.本节讲到以日期进行bucket分组操作,也就是说把连续的日期变成离散的日期区间,然 ...

  10. python爬虫20 | 小帅b教你如何使用python识别图片验证码

    当你在爬取某些网站的时候 对于你的一些频繁请求 对方会阻碍你 常见的方式就是使用验证码 验证码的主要功能 就是区分你是人还是鬼(机器人) 人 想法设法的搞一些手段来对付技术 而 技术又能对付人们的想法 ...