初识AJAX

131 阅读1分钟

原生AJAX调用接口分为一下四步: 1.创建对象 2.初始化 设置请求方法和url 3.发送 4. 绑定事件 处理服务端返回的结果 代码展示如下:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>AJAX GET 请求</title>
    <style>
        #result {
            width: 200px;
            height: 200px;
            border: 1px solid red;
        }
    </style>
</head>

<body>
    <button type="button">点我发送请求</button>
    <div id="result"></div>
    <script>
        const btn = document.querySelector('button');
        const result = document.getElementById('result');
        btn.onclick = function () {
            // 1.创建对象
            const xhr = new XMLHttpRequest();   // readystate 为0  表示未初始化
            // 2.初始化 设置请求方法和url
            xhr.open('GET', 'http://127.0.0.1:8000/serve?a=100&b=200&c=300');  //readystate 为1  表示open 方法已经调用完毕       ?a=100&b=200$c=300表示在AJAX中设施请求参数,多个参数用&隔开    
            //
            // 3. 发送
            xhr.send();                 // readystate 为2  send 方法已经调用完毕
            //  readystate 为3 表示服务端返回了部分结果
            //  readystate 为4 表示服务端返回了所有结果
            // 4. 绑定事件 处理服务端返回的结果
            // readystate 是xhr对象的属性 表示状态 有0,1,2,3,4 五个值
            // change  改变  readystate状态值每改变一次触发一次事件,总共触发4次
            xhr.onreadystatechange = function () {
                //  判断(服务端返回所有结果后再去处理)
                if (xhr.readyState === 4) {
                    //  判断响应状态码  200  404 403
                    // 2xx  以2开头的都算成功
                    if (xhr.status >= 200 && xhr.status < 300) {
                        // 满足所有条件后开始处理结果
                        // console.log(xhr.status); // 响应行里的响应状态码
                        // console.log(xhr.statusText); //响应行里的响应字符串
                        // console.log(xhr.getAllResponseHeaders());  // 所有响应头
                        // console.log(xhr.response);  // 响应体
                        result.innerHTML = xhr.response;
                    }
                }
            }
        }
    </script>
</body>

</html>

服务端代码如下:

// 1. 引入expres
const { request, response } = require('express');
const express = require('express');
// 2. 创建应用对象
const app = express();
//3. 创建路由规则

// request是对请求报文的封装
// response是对响应报文的封装
app.get('/serve', (request, response) => {
     // 设置响应头   设置允许跨域
     response.setHeader('Access-Control-Allow-Origin', '*');
     // 设置响应体
     response.send('HELLO AJAX');
 
});
// 4.监听端口启动服务
app.listen(8000,()=>{
    console.log('服务已启动, 8000 端口监听中.......');
});

作者此处简单的使用了express框架,需要安装node.js环境,在此不做多余的阐述,想了解的朋友请自行百度