AJAX:整理3:原生AJAX的相关操作

注意AJAX的步骤 

// 1.创建对象
const xhr = new XMLHttpRequest()

// 2.初始化 设置 请求方法 和 url
xhr.open("GET", "http://localhost:9090/server")

// 3.发送
xhr.send()

// 4.事件绑定 处理服务端返回的结果
// readyState 是xhr对象中的属性,表示状态 0 1 2 3 4  
// 0 表示初始值; 1 表示open()方法调用完毕;2 表示send()方法调用完毕;3 表示服务端返回了部分结果;4 表示服务端返回了所有的结果

// change 改变
xhr.onreadystatechange = function () { 
    // 判断状态码
    if (xhr.readyState === 4) {
        // 判断状态码
        if (xhr.status >= 200 && xhr.status < 300) {
          // 获取服务端返回的结果 (行 头 空行 响应体)
            console.log(xhr.status) // 响应行里面的响应状态码  200
            console.log(xhr.statusText) // 状态字符串  OK
            console.log(xhr.getAllResponseHeaders()) // 所有响应头

            console.log(xhr.response)  // 响应体
            const result = xhr.response 
         }
    }
 }

1. GET 请求

需求:向服务端发送get请求,拿到服务端返回的结果,并显示在div盒子中

(1)server.js

// 1. 引入express
const express = require('express')

// 2. 创建服务器
const app = express()

// 3.创建路由规则
// request 是对请求报文的封装
// response 是对响应报文的封装
app.get('/server', (request, response)  => {
    // 设置响应头  设置允许跨域  !!!
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 设置响应体
    response.send('HELLO AJAX GET')
})


// 4. 监听端口
app.listen(9090, () => {
    console.log("服务已启动, 9090端口监听中...")
}) 

(2)前端页面并渲染服务端返回的结果




    
    
    ajax GET 请求
    


    
    

 AJAX:整理3:原生AJAX的相关操作_第1张图片

AJAX:整理3:原生AJAX的相关操作_第2张图片

2. GET请求携带参数

AJAX:整理3:原生AJAX的相关操作_第3张图片

AJAX:整理3:原生AJAX的相关操作_第4张图片

3. POST请求 

当鼠标放在div盒子上时,向服务端发送post请求,将响应的结果在div中呈现

 (1)server.js

// 1. 引入express
const express = require('express')

// 2. 创建服务器
const app = express()

// 3.创建路由规则
// request 是对请求报文的封装
// response 是对响应报文的封装
app.post('/server', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')

    // 设置响应体
    response.send('HELLO AJAX POST')
})

// 4. 监听端口
app.listen(9090, () => {
    console.log("服务已启动, 9090端口监听中...")
}) 

(2)前端页面并渲染数据到盒子中




    
    
    ajax POST 请求
    


    

AJAX:整理3:原生AJAX的相关操作_第5张图片

4. POST请求中设置参数

AJAX:整理3:原生AJAX的相关操作_第6张图片

 AJAX:整理3:原生AJAX的相关操作_第7张图片

 5.  AJAX设置请求头信息

AJAX:整理3:原生AJAX的相关操作_第8张图片

 AJAX:整理3:原生AJAX的相关操作_第9张图片

但是如果自定义一个请求头呢,浏览器会有安全机制,不让发送

AJAX:整理3:原生AJAX的相关操作_第10张图片

如果我们非要发的话,可以用以下的方法 

AJAX:整理3:原生AJAX的相关操作_第11张图片

AJAX:整理3:原生AJAX的相关操作_第12张图片

6. 服务端响应JSON数据

需求:当点击键盘时,会向服务端发送请求,服务端响应结果会在div盒子中呈现

AJAX:整理3:原生AJAX的相关操作_第13张图片




    
    
    Document
    



    

 AJAX:整理3:原生AJAX的相关操作_第14张图片

 1. 手动转换

AJAX:整理3:原生AJAX的相关操作_第15张图片

AJAX:整理3:原生AJAX的相关操作_第16张图片

2.自动转换

AJAX:整理3:原生AJAX的相关操作_第17张图片

7. AJAX解决IE缓存问题

IE浏览器会对请求结果作一个缓存,这样就会导致一个问题,就是下一次再发送请求时,走的就是本地的缓存,而并不是服务器返回的最新数据

/* 针对IE缓存问题 */
app.all('/ie', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受

    // 设置响应体
    response.send("hello IE")
})



    
    
    Document
    


    
    

 AJAX:整理3:原生AJAX的相关操作_第18张图片

8. AJAX请求超时以及网络异常处理

1.请求超时

AJAX:整理3:原生AJAX的相关操作_第19张图片




    
    
    Document
    


    
    

 AJAX:整理3:原生AJAX的相关操作_第20张图片

AJAX:整理3:原生AJAX的相关操作_第21张图片 

 

 2. 网络异常

AJAX:整理3:原生AJAX的相关操作_第22张图片

 

9. AJAX取消请求

AJAX:整理3:原生AJAX的相关操作_第23张图片

 

AJAX:整理3:原生AJAX的相关操作_第24张图片

 

10. AJAX解决请求重复发送问题

当请求响应比较慢的时候,用户就会疯狂地点击,这时候服务器就会接收到大量的相同请求,服务器压力比较大

所以我们需要保证始终只有一个请求在发送,这样服务器的压力就会小一些 

AJAX:整理3:原生AJAX的相关操作_第25张图片

AJAX:整理3:原生AJAX的相关操作_第26张图片

 AJAX:整理3:原生AJAX的相关操作_第27张图片

 

11. jQuery发送AJAX请求

首先需要引入jQuery资源

11.1 发送GET请求

app.get('/jquery', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受

    response.send("hello jQuery AJAX")
})

 

$("#btn1").click(function() {
   // 第一个参数是url, 第二个参数是发送的参数(对象的形式), 第三个参数是回调函数
   $.get("http://localhost:9090/jquery", {a:100, b:200}, function(data, status) {
           console.log(data)
   })
})

AJAX:整理3:原生AJAX的相关操作_第28张图片 

 

11.2 发送POST请求

app.post('/jquery', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受

    response.send("hello jQuery AJAX POST")
})
$("#btn2").click(function() {
     $.post("http://localhost:9090/jquery", {a:100, b:200}, function(data, status) {
           console.log(data)
     })
})

POST请求携带的参数不会跟在url后面 

AJAX:整理3:原生AJAX的相关操作_第29张图片

11.3  设置响应体的数据类型

/* jQuery服务 */
app.all('/jquery', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受
    const data = {name: "xiexu", age: 20}

    response.send(JSON.stringify(data))
})

服务端发送json格式的数据

 

AJAX:整理3:原生AJAX的相关操作_第30张图片

 

AJAX:整理3:原生AJAX的相关操作_第31张图片

11.4 jQuery通用方法发送AJAX请求

AJAX:整理3:原生AJAX的相关操作_第32张图片

 

AJAX:整理3:原生AJAX的相关操作_第33张图片

 

AJAX:整理3:原生AJAX的相关操作_第34张图片

12. Axios发送AJAX请求

首先需要引入axios工具包 

 12.1 发送GET请求

app.get('/axios', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受

    response.send("hello Axios AJAX")
})

AJAX:整理3:原生AJAX的相关操作_第35张图片

获取的数据是比较完整的

AJAX:整理3:原生AJAX的相关操作_第36张图片

 

12.2 发送POST请求

AJAX:整理3:原生AJAX的相关操作_第37张图片

 

/* axios 服务*/
app.all('/axios', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受

    response.send("hello Axios AJAX POST")
})

 AJAX:整理3:原生AJAX的相关操作_第38张图片

12.3 Axios通用方式发送AJAX请求

AJAX:整理3:原生AJAX的相关操作_第39张图片

AJAX:整理3:原生AJAX的相关操作_第40张图片 

 

13. fetch() 函数发送AJAX请求 

/* fetch */
app.all('/fetch', (request, response)  => {
    // 设置响应头  设置允许跨域
    response.setHeader('Access-Control-Allow-Origin', '*')
    // 响应头
    response.setHeader('Access-Control-Allow-Headers', '*')  // 所有类型的头信息都可以接受
    const data = {name: "x666", age: 20}

    // response.send("hello jQuery AJAX")
    response.send(JSON.stringify(data))
})

AJAX:整理3:原生AJAX的相关操作_第41张图片 

AJAX:整理3:原生AJAX的相关操作_第42张图片 

 

 14. 解决跨域问题

同源策略是最早由Netscape公司提出,是浏览器的一种安全策略

同源:协议、域名、端口号必须相同;  违背同源策略就是跨域

解决跨域的方法:

14.1 JSONP

JSONP是一个非官方的跨域解决方案,只支持get请求

(1)JSONP是怎么工作的?

在网页中,由一些标签天生具有跨域的能力,比如img、link、iframe、script,JSONP就是利用script标签的跨域能力来发送请求的

(2)JSONP实现原理




    
    
    jsonp解决跨域问题


    

app.all('/jsonp', (request, response)  => {
    response.send("hello jsonp")
})

AJAX:整理3:原生AJAX的相关操作_第43张图片

 

 这个原因就是我正儿八经的script标签向你发送请求,你却返回一个字符串的形式,我们应该返回的是函数的调用,也就是js的代码,这样浏览器才能执行里面的内容

AJAX:整理3:原生AJAX的相关操作_第44张图片

 

AJAX:整理3:原生AJAX的相关操作_第45张图片 

 

14.2 原生JSONP的实现

需求:有一个输入框,在里面输入用户名,输完之后,我会失去焦点,失去焦点的时候,就会向服务端发送请求,对用户名是否存在的检测,因为这边没有数据库,所以服务端直接返回一个已存在,结果回来之后了,我们作一个判断,再把input框的颜色变为红色

 

/* 用户名检测是否存在 */
app.all('/checkUserName', (request, response)  => {
    const data = {
        exists: 1,
        msg: "用户名已存在"
    }
    let str = JSON.stringify(data)

    response.send(`handle(${str})`)
})

AJAX:整理3:原生AJAX的相关操作_第46张图片 

AJAX:整理3:原生AJAX的相关操作_第47张图片 

14.3 jQuery发送JSONP请求

需求:点击按钮,向服务端发送请求,响应的结果再div盒子中呈现

AJAX:整理3:原生AJAX的相关操作_第48张图片

AJAX:整理3:原生AJAX的相关操作_第49张图片 

AJAX:整理3:原生AJAX的相关操作_第50张图片 

 

14.4 设置CORS响应头实现跨域

(1)CORS是什么?

CORS(Cross-Origin Resource Sharing), 跨域资源共享。CORS是官方的跨域解决方案,它的特点是不需要在客户端做任何特殊的操作,完全在服务器中进行处理,支持get和post请求。跨域资源共享标准新增了一组HTTP首部字段,允许服务器声明哪些源站通过浏览器有权限访问哪些资源。

(2)CORS是怎么工作的?

CORS通过设置一个响应头告诉浏览器,请允许跨域,浏览器收到该响应以后就会对响应放行

 

AJAX:整理3:原生AJAX的相关操作_第51张图片

AJAX:整理3:原生AJAX的相关操作_第52张图片

 AJAX:整理3:原生AJAX的相关操作_第53张图片

修改:添加响应头

AJAX:整理3:原生AJAX的相关操作_第54张图片

 

 成功响应:

AJAX:整理3:原生AJAX的相关操作_第55张图片

你可能感兴趣的:(AJAX,ajax)