在这里插入图片描述
一、是什么
AJAX全称(Async Javascript and XML)

异步的JavaScript 和XML,是一种创建交互式网页应用网页开发技术可以在不重新加载整个网页的情况下,与服务器交换数据,并且更新部分网页

Ajax原理简单来说通过XmlHttpRequest对象来向服务器异步请求,从服务器获得数据然后用JavaScript操作DOM而更新页面
流程图如下
在这里插入图片描述
举个粟子:

领导想找小李汇报一下工作,就委托秘书去叫小李,自己就接着做其他事情,直到秘书告诉他小李已经到了,最后小李跟领导汇报工作

Ajax请求数据流程与“领导想找小李汇报一下工作”类似,上述秘书就相当于XMLHttpRequest对象,领导相当于浏览器响应数据相当于小李

浏览器可以发送HTTP请求后,接着做其他事情,等收到XHR返回来的数据再进行操作

二、实现过程
实现 Ajax异步交互需要服务器逻辑进行配合,需要完成以下步骤

创建XMLHttpRequest对象

通过XMLHttpRequest() 构造函数用于初始化一个 XMLHttpRequest 实例对象

const xhr = new XMLHttpRequest();

服务器建立连接

通过 XMLHttpRequest 对象的 open() 方法服务器建立连接

xhr.open(method, url, [async][, user][, password])

参数说明

服务端发送数据
通过 XMLHttpRequest 对象的 send() 方法,将客户端页面数据发送给服务

xhr.send([body])

body: 在 XHR 请求中要发送数据体,如果不传递数据则为 null

如果使用GET请求发送数据时候需要注意如下

绑定onreadystatechange事件
onreadystatechange 事件用于监听服务器端的通信状态,主要监听属性为XMLHttpRequest.readyState ,

关于XMLHttpRequest.readyState属性有五个状态,如下图显示
在这里插入图片描述
只要 readyState属性值一变化,就会触发一次 readystatechange 事件
XMLHttpRequest.responseText属性用于接收服务器端的响应结果

举个粟子:

const request = new XMLHttpRequest()
request.onreadystatechange = function(e){
    if(request.readyState === 4){ // 整个请求过程完毕
        if(request.status &gt;= 200 &amp;&amp; request.status <= 300){
            console.log(request.responseText) // 服务返回结果
        }else if(request.status &gt;=400){
            console.log("错误信息:" + request.status)
        }
    }
}
request.open('POST','http://xxxx')
request.send()

三、封装

通过上面对XMLHttpRequest对象的了解,下面来封装一个简单ajax请求

// 封装一个ajax请求
function ajax(options){
//创建XMLHttpRequest对象
const xhr = new XMLHttpRequest()

// 初始化参数的内容
options = options || {}
options.type = (options.type||"GET").toUpperCase()
options.dataType = options.dataType || 'application/json'
options.responseType  = options.responseType  || 'json'
const params = options.data

xhr.setRequestHeader('content-type',options.dataType)
xhr.responseType  = options.responseType
// 发送请求
if(options.type==="GET"){
  xhr.open("GET",options.url+"?"+params,true)
  xhr.send(null)
  }else{
  xhr.open("POST",options.url,true)
  xhr.send(params)
  }
  // 接受请求
  xhr.onreadystatechange = function(){
       if(xhr.redayState ===4){
         let status = xhr.status
         if(status&gt;=200&amp;&amp;status<300){
           options.success &amp;&amp; options.success(xhr.responseText,xhr.responseXML)
           }else{
           options.fail &amp;&amp; options.fail(status)
           }
        }
   }
}

responseType格式
IE不用考虑了,停止维护了。
容易忽略:用了默认值返回就是个字符串,你需要JSON.parse()处理一下
xhr.responseType = ‘blob设置这个时候,你获取到的就是一个二进制字符串,当后端给你返回图片文件时候你就得这么处理
在这里插入图片描述

使用方式如下

ajax({
         type: 'post',
         dataType: 'json',
         responseType: 'json',
         data: {},
         url: 'https://xxx',
         success: function(text,xml){ //请求成功后的回调函数
         },
         fail: function(status){ // 请求失败后的回调函数
         }
})

原文地址:https://blog.csdn.net/qq_34595425/article/details/131015658

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_37488.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注