AJAX发送http请求、接收响应教程带展示(全文精华)
AJAX(Asynchronous JavaScript and XML)(异步)
特点:在不重新加载整个网页的情况下,与服务器交换数据并对网页进行部分更新
用途:快速动态交互网页
XML(eXtensible Markup Language)—— 可扩展标记语言,传输和存储网页数据。
HTML(HyperText Markup Language)——超文本标记语言,创建和显示网页数据
干货奉上!!!
基础语法示例一
- Question:设请求名为 X使用GET方法,访问本地主机的8888号端口,使用异步方法
-
x=new XMLHttpRequest();
-
-
x.open("GET","http://localhost:8888",true);
-
-
x.send();
- 参数解析:open(method,url,async)
- method:请求的方法,GET 或 POST
- url:文件在服务器上的位置
- async:true(异步)、 false(同步)
-
异步:在等待服务器响应时执行其他脚本,当响应就绪后对响应进行处理
-
同步:服务器响应后再执行其他脚本,处理响应,仅适用小型的请求
-
- 特别注意:send中可加入字符串,但仅限于POST请求,表示法:x.send(‘字符串内容’)
基础语法示例二
- Question:设置请求header中Content-Length的值为999,resp_text保存字符串形式的响应数据,resp_xml 形式的响应数据。
-
x.setRequestHeader("Content-Length","999")
-
-
resp_text = x.responseText
-
-
resp_xml = x.responseXML
- 参数解析:setRequestHeader(header_parameter,value)
- header: 设置指定头部的参数的名称
- value: 设置指定头部的参数的值
基础语法示例三
-
知识补充
- 使用AJAX发送的XMLHttpRequest有四种状态,从 0 到 4 发生变化。
- 0: 请求未初始化
- 1: 服务器连接已建立
- 2: 请求已接收
- 3: 请求处理中
- 4: 请求已完成,且响应已就绪
- 服务器返回的响应会带有状态码(status),状态码含义:
- 1xx:信息响应类,表示接收到请求并且继续处理
- 2xx:处理成功响应类,表示动作被成功接收、理解和接受
- 例如:200 OK
- 3xx:重定向响应类,为了完成请求,客户端要采取进一步操作
- 4xx:客户端错误,客户请求包含语法错误或者是不能正确执行
- 例如:404 Not Found
- 5xx:服务端错误,服务器不能正确执行一个正确的请求
-
语法示例
- 异步处理时,当 readyState 属性改变时,就会调用函数onreadystatechange
- x.onreadystatechange=function(){判断语句块 处理语句}
- Question:当响应已就绪,并且服务器成功处理响应时,在控制台打印Success
-
x.onreadystatechange=function(){
-
-
if (x.readyState==4 && x.status==200){
-
-
console.log('Success');
-
}
-
}
进阶语法示例
- Question:
- 以状态码的文本(一般为空),并保存在 st 中
- 获取响应头的所有信息,并保存在 all 中
- 获取响应头Content-Length信息,并保存在 cl 中
- 获取响应头的文本信息,并且以JSON编码的方式保存在 j 中
- 以JSON编码的方式直接发送JSON格式的文本
- { "Name": "admin", "response": { "password": "nice" } }
-
st = x.statusText
-
all = x.getAllResponseHeaders();
-
cl = x.getResponseHeader('Content-Length');
-
j = JSON.parse(x.responseText);
-
x.send(JSON.stringify({ "Name": "admin", "response": { "password": "nice" } }));
- 回调函数:一个网站上存在多个 AJAX 任务,编写创建XMLHttpRequest 对象的函数,并为每个 AJAX 任务调用该函数
服务器响应状态码status列表
- 100——部分请求已被接收,客户应继续发出请求
- 101——服务器令客户端根据请求转换HTTP协议版本
- 200——请求成功
- 201——请求已被接受,等待资源响应,已知道新文件的URL
- 202——接受和处理、但处理未完成
- 203——服务器返回信息不确定或不完整
- 204——请求成功收到,但服务器返回信息为空
- 205——服务器完成了请求,用户代理必须复位(重置)当前已经浏览过的文件
- 206——服务器完成了部分GET请求,断点续传,大文件分段
- 300——请求的资源可在多处得到
- 301——被请求的资源已永久移动到新位置
- 302——请求的资源在其他的URL中发现
- 303——建议客户访问其他URL或访问方式
- 304——客户端已经执行了GET,但文件未变化
- 305——请求的资源必须从服务器指定的地址得到(或通过指定的代理得到)
- 306——前一版本HTTP中使用的代码,现行版本中不再使用
- 307——申明请求的资源临时性删除
- 400——错误请求,如语法错误
- 401——请求授权失败
- 402——保留有效ChargeTo头响应
- 403——服务器拒绝此请求
- 404——找不到文件或URl
- 405——用户在Request-Line字段定义的方法不允许
- 406——根据用户发送的Accept拖,请求资源不可访问
- 407——类似401,用户必须首先在代理服务器上得到授权
- 408——请求超时
- 409——对当前资源状态,请求不能完成
- 410——服务器上不再有此资源且无进一步的参考地址
- 411——服务器拒绝用户定义的Content-Length属性请求
- 412——一个或多个请求头字段在当前请求中错误
- 413——请求的资源大于服务器允许的大小
- 414——请求的资源URL长于服务器允许的长度
- 415——请求资源不支持请求项目格式
- 416——请求中包含Range请求头字段,在当前请求资源范围内没有range指示值,请求也不包含If-Range请求头字段
- 417——服务器不满足请求Expect头字段指定的期望值,如果是代理服务器,可能是下一级服务器不能满足请求
- 500——服务器产生内部错误
- 501——服务器不支持请求的函数
- 502——服务器暂时不可用,有时是为了防止发生系统过载
- 503——服务器过载或暂停维修
- 504——关口过载,服务器使用另一个关口或服务来响应用户,等待时间设定值较长
- 505——服务器不支持或拒绝支请求头中指定的HTTP版本
本篇文章来至:学新通
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通
- 本文地址: https://www.swvq.com/boutique/detail/tanhckejfh
- 联系方式: luke.wu#vfv.cc
系列文章
更多
同类精品
更多
精彩评论
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word只能打字母不能打汉字怎么办
PHP中文网 06-28 -
pr做好的序列不见了怎么办
PHP中文网 05-12 -
微信小程序没声音怎么办
PHP中文网 06-15 -
word表格总是自动分成两个怎么办
PHP中文网 06-20 -
手机怎样打开html文件
PHP中文网 05-20 -
电脑开机后点击任务栏没反应怎么办
PHP中文网 06-24 -
微信提示登录环境异常是什么意思原因
PHP中文网 04-09 -
怎样阻止微信小程序自动打开
PHP中文网 06-13