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版本
  • 9
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是羽十八ya

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值