AJAX的具体使用
一、GET请求
①GET请求传递参数通常使用的是问号传参,即在请求地址上加上?参数,从而传递数据到服务端
②一般在GET请求数据时,无需设置响应体,可以传null或者干脆不传
③一般情况下URL传递的都是参数性质的数据,而POST一般都是业务数据
<?php
//test.php服务端文件
//返回的响应就是数据,对于返回数据的地址一般称之为接口(有输入有输出),形式上上是web形式
$data=array(
array('id' => 1,'name' =>'刘备','age' => 30),
array('id' => 2,'name' =>'关羽','age' => 29),
array('id' => 3,'name' =>'张飞','age' => 28)
);
//处理数据
if(empty($_GET['id'])){
//没有ID则获取全部数据
//因为HTTP中约定报文的内容就是字符串,需要传递给客户端的是信息是一个有结构的数据
//这种情况下一般采用json作为数据格式
$json=json_encode($data);
echo $json;
}else{
//传递了ID只获取一条
foreach($data as $item){
if($item['id']==$_GET['id']){
$json=json_encode($item);
echo $json;
}
}
}
?>
<body>
<ul id="list"></ul>
<script>
var listElement=document.getElementById("list");
var xhr=new XMLHttpRequest();
xhr.open('GET','http://localhost/test.php');
xhr.send();
xhr.onreadystatechange=function(){
if(this.readyState!==4) return;
//JSON.parse()方法用于将一个JSON字符串转换为对象
var data=JSON.parse(this.responseText);
//遍历对象
for(var i=0;i<data.length;i++){
//增加一个li元素
var liElement=document.createElement('li');
//li元素里面写入的是服务端数据的name值
liElement.innerHTML=data[i].name;
//便于后面获取当前被点击元素对应数据的ID
liElement.id=data[i].id;
//把li元素添加到ul里面
listElement.appendChild(liElement);
//为li元素注册点击事件,使用addEventListener的好处是可以为一个元素注册多个事件,不会冲突
liElement.addEventListener('click',function(){
//通过AJAX操作获取服务器端对应数据的信息
var xhr1=new XMLHttpRequest();
xhr1.open('GET','http://localhost/test.php?id=' + this.id);
xhr1.send();
xhr1.onreadystatechange=function(){
if(this.readyState!==4) return;
var obj = JSON.parse(this.responseText);
console.log(obj);
alert(obj.age);
};
});
}
}
</script>
</body>
二、POST请求
①post请求过程中,都是采用请求承载需要提交的数据
②open()方法的第一个参数就是设置请求的method
③setRequestHeader中需要设置Content-Type的格式与send( )里参数的格式相对应
④用户可以自定义加载页面,只要利用display的none和block结合请求的状态变化就可以实现
⑤案例:
<?php
//test.php服务端文件
//接收用户端提交的用户名和密码
if(empty($_POST['username']) || empty($_POST['password'])){
exit('请提交用户名和密码');
}
//校验
$username=$_POST['username'];
$password=$_POST['password'];
if($username==='admin' && $password='123'){
exit('登录成功');
}
exit('用户名或者密码错误');
?>
<body>
<table border="1">
<tr>
<td>用户名</td>
<td><input type="text" name="username" id="username"></td>
</tr>
<tr>
<td>密码</td>
<td><input type="password" name="password" id="password"></td>
</tr>
<tr>
<td></td>
<td><button type="submit" id="btn">登录</button></td>
</tr>
</table>
<script>
//声明变量
var btn=document.getElementById("btn");
var txtUsername=document.getElementById("username");
var txtPassword=document.getElementById("password");
//为btn注册点击事件
btn.onclick=function(){
//获取用户填入的值
var username=txtUsername.value;
var password=txtPassword.value;
//通过xhr发送一个POST请求
var xhr=new XMLHttpRequest();
xhr.open('POST','http://localhost/test.php');
//设置请求头的格式,与请求体urlencoded的格式对应
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
//设置请求体,格式为urlencoded,注意`{}`这样的写法
xhr.send(`username=${username}&password=${password}`);
//根据服务端的反馈,作出页面提示
xhr.onreadystatechange=function(){
if(this.readyState!==4) return;
console.log(this.responseText);
}
}</script>
</body>
三、同步和异步
①概念
- 同步可以理解为一个人在同一时刻只能做一件事情,在执行一些耗时的操作(不需要看管)不去做其他的事,只是等待。同步的思想是:所有的操作都做完,才返回给用户。这样用户在线等待的时间太长,给用户一种卡死了的感觉(就是系统迁移中,点击了迁移,界面就不动了,但是程序还在执行,卡死了的感觉)。这种情况下,用户不能关闭界面,如果关闭了,即迁移程序就中断了。
- 异步可以理解为在执行一些耗时的操作时(不需要看管)去做别的事,而不是等待。将用户请求放入消息队列,并反馈给用户,系统迁移程序已经启动,你可以关闭浏览器了。然后程序再慢慢地去写入数据库去。这就是异步。但是用户没有卡死的感觉,会告诉你,你的请求系统已经响应了。你可以关闭界面了。
②设置:open()方法第三个参数是传入一个bool值,其作用就是设置此次请求是否采用异步方式执行 ,默认为true,如果需要同步执行可以通过传递false实现
<script>
console.log('before ajax');
var xhr=new XMLHttpRequest();
xhr.open('GET','http://localhost/test.php',true);
xhr.send(null);
xhr.onreadystatechange=function(){
if(this.readyState===4){
console.log('加载完成');
}
}
console.log('after ajax');
//控制台输出:
//before ajax
//after ajax
//加载完成
</script>
<script>
var xhr=new XMLHttpRequest();
xhr.open('GET','http://localhost/test.php',false);
//同步方式执行会在send()发送请求以后等待一段时间,直到readyState为4才会继续往下执行代码
xhr.send(null);
//所以不需要注册事件,就可以拿到数据了,或者如果需要注册事件,一定需要在send方法调用之前注册事件,否则无法触发
console.log(xhr.readyState);//4
// xhr.onreadystatechange=function(){
// if(this.readyState===4){
// console.log('加载完成');
// }
// }
console.log(xhr.responseText);//1529918265
//并且控制台会提醒这种方式会导致用户体验不佳:
//[Deprecation] Synchronous XMLHttpRequest on the main thread is deprecated because of its detrimental effects to the end user's experience.
</script>
③结论:
- 同步,是所有的操作都做完,才返回给用户结果。即写完数据库之后,在相应用户,用户体验不好。
- 异步,不用等所有操作等做完,就相应用户请求。即先相应用户请求,然后慢慢去写数据库,用户体验较好。
四、响应数据类型
- 如果服务端返回的各种格式的数据,这种格式的数据都需要在客户端使用JavaScript解析
- XML是一种数据描述手段,由于数据冗杂太多,现在基本被淘汰
<?xml version="1.0" encoding="utf-8" ?>
<users>
<user>
<username>张三</username>
<age>23</age>
</user>
<user>
<username>李四</username>
<age>24</age>
</user>
</users>
<script>
var xhr=new XMLHttpRequest();
xhr.open('GET','user.xml');
xhr.send();
xhr.onreadystatechange=function(){
if(this.readyState!==4) return;
var name1=this.responseXML.documentElement.getElementsByTagName("username")[0].innerHTML;
var age1=this.responseXML.documentElement.getElementsByTagName("age")[0].innerHTML;
console.log(name1+":"+age1);//张三:23
}
</script>
- JSON也是一种数据描述手段,类似于JavaScript字面量方式,服务端采用JSON格式返回数据,客户端按照JSON格式解析数据
[
{ "username" : "张三", "age" : 23},
{ "username" : "李四", "age" : 24}
]
<script>
var xhr=new XMLHttpRequest();
xhr.open('GET','user.json');
xhr.send();
xhr.onreadystatechange=function(){
if(this.readyState!==4) return;
var obj=JSON.parse(this.responseText);
var name2=obj[1].username;
var age2=obj[1].age;
console.log(name2+":"+age2);//李四:24
}
</script>
- 不管服务端采用的是XML格式的数据还是JSON格式的数据,本质上都是将数据返回给客户端
- 服务端应该设置一个合理的Content-Type
五、其他
①response获取到的结果会根据responseType的变化而变化,而responseText永远获取的都是字符串形式的响应体
<script>
var xhr=new XMLHttpRequest();
xhr.open('GET','test.php');
xhr.send();
//responseType还允许作者将响应类型更改为一个"arraybuffer", "blob", "document", "json", 或 "text" 。
//如果将一个空字符串设置为responseType的值,则将其假定为类型“text”,即 "" 等效于 "text";
//兼容性不是很好,推荐使用responseText
xhr.responseType='';
xhr.onreadystatechange=function(){
if(this.readyState!==4) return;
console.log(this.response);
}
</script>
②兼容方案:XMLHttpReuquest在老版本浏览器(IE5/6)中有兼容问题,可以通过另外一种方式代替
//兼容IE5/6
var xhr=window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHttp");
③补充:Chrome中控制台展开被打印的对象时,会访问即时的数据
<script>
var obj={foo:123};
console.log(obj);
setTimeout(function(){
obj.foo=456;
console.log(obj);
},3000)
//说明:
//打开控制台,如果先打开{foo: 123},还未出现{foo: 456},看到的前面foo的值是123,后面foo的值是456;
//打开控制台,如果{foo: 123}和{foo: 456}都已经显示,打开任何一个看到的值都是456
</script>
AJAX的具体使用的更多相关文章
- jQuery之ajax实现篇
jQuery的ajax方法非常好用,这么好的东西,你想拥有一个属于自己的ajax么?接下来,我们来自己做一个简单的ajax吧. 实现功能 由于jq中的ajax方法是用了内置的deferred模块,是P ...
- Ajax及跨域
概念 Ajax Ajax,Asynchronous JavaScript and XML,字面意思:异步的 JavaScript 和 XML,是指一种创建交互式网页应用的网页开发技术. 用于异步地去获 ...
- 一个粗心的Bug,JSON格式不规范导致AJAX错误
一.事件回放 今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...
- ABP文档 - Javascript Api - AJAX
本节内容: AJAX操作相关问题 ABP的方式 AJAX 返回信息 处理错误 HTTP 状态码 WrapResult和DontWrapResult特性 Asp.net Mvc 控制器 Asp.net ...
- ajax异步请求
做前端开发的朋友对于ajax异步更新一定印象深刻,作为刚入坑的小白,今天就和大家一起聊聊关于ajax异步请求的那点事.既然是ajax就少不了jQuery的知识,推荐大家访问www.w3school.c ...
- 调用AJAX做登陆和注册
先建立一个页面来检测一下我们建立的用户名能不能用,看一下有没有已经存在的用户名吗 可以通过ajax提示一下 $("#uid").blur(function(){ //取用户名 va ...
- Ajax 概念 分析 举例
Ajax是结合了访问数据库,数据访问,Jquery 可以做页面局部刷新或者说是页面不刷新,我可以让页面不刷新,仅仅是数据的刷新,没有频繁的刷页面,是现在比较常用的一种方式做页面那么它是怎么实现页面无刷 ...
- ajax
常见的HTTP状态码状态码:200 请求成功.一般用于GET和POST方法 OK301 资源移动.所请求资源移动到新的URL,浏览器自动跳转到新的URL Moved Permanently304 未修 ...
- 学习笔记之MVC级联及Ajax操作
由于刚转型到MVC,MVC的架构模式很多不是很清楚,比如今天就想做个级联的操作,因为之前的ASP.NET的方式是通过:控件-->添加事件-->后台编写级联事件进行触发,但是这个MVC就不同 ...
- javascript表单的Ajax 提交插件的使用
Ajax 提交插件 form.js 表单的下载地址:官方网站:http://malsup.com/jquery/form/ form.js 插件有两个核心方法:ajaxForm()和ajaxSubmi ...
随机推荐
- Vue.js 2.x render 渲染函数 & JSX
Vue.js 2.x render 渲染函数 & JSX Vue绝大多数情况下使用template创建 HTML.但是比如一些重复性比较高的场景,需要运用 JavaScript 的完全编程能力 ...
- 【LEETCODE】52、数组分类,简单级别,题目:717,661,746,628,643,849
package y2019.Algorithm.array; /** * @ProjectName: cutter-point * @Package: y2019.Algorithm.array * ...
- tkinter python(图形开发界面) 转自:渔单渠
Tkinter模块("Tk 接口")是Python的标准Tk GUI工具包的接口.Tk和Tkinter可以在大多数的Unix平台下使用,同样可以应用在Windows和Macinto ...
- vscode 连接远程服务器 sftp
1.在vscode 应用商店搜索 sftp 下载安装 2.ctrl+shift+p 搜索sftp:config 生成sftp.json 3.配置你的服务器信息{ "name": & ...
- 物流管理系统(SSM+vue+shiro)【前后台】
一.简单介绍项目 该项目是属于毕业设计项目之一,有前台的用户下单.有司机进行接单.有管理员进行操作后台,直接进入主题 毕设.定制开发 联系QQ:761273133 登录主页: 手机号码+验证码登录 或 ...
- Bootstrap-table 使用总结,和其参数说明
转载于:https://www.cnblogs.com/laowangc/p/8875526.html 一.什么是Bootstrap-table? 在业务系统开发中,对表格记录的查询.分页.排序等处理 ...
- Java性能优化学习笔记
1. 尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间,提高加载的效率,但并不是所有地方都适用于单例,简单来说,单例主要适用于以下三个方面: 第一,控制资源的使用,通过线程同步来控 ...
- 11.15java实习生面试总结
坐了两个小时的车,到了面试地点面了十五分钟左右就结束了,心里有一点难受,不过这也是刚开始,后面的路还长着呢,所以先把面试官问的题目记录下来. 1.C语言能否跨平台? 虽然我面的是java实习生,但是因 ...
- Java NIO和IO的区别
下表总结了Java NIO和IO之间的主要差别,我会更详细地描述表中每部分的差异. 复制代码 代码如下: IO NIO面向流 面向缓冲阻塞IO 非阻塞IO无 选择器 面向流与面向缓冲 Java NIO ...
- DataPipeline的增量数据支持回滚功能
DataPipeline的增量数据支持回滚功能 第一步:数据任务有增量数据时,回滚按钮激活,允许用户使用该功能进行数据回滚. 第二步:点击回滚按钮,允许用户选择回滚时间或者回滚位置进行数据回滚.选择按 ...