xhr 的简单使用

Ajax = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。
Ajax 不是新的编程语言,而是一种使用现有标准的新方法。
它最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。并且不需要任何浏览器插件,但需要用户允许JavaScript在浏览器上执行。
总的来说,就是:

ajax 是数据请求方式的一种,
1. 前端可以发送数据到后端
2. 可以接受从后端传过来的数据
3. 可以解析从后端传过来的数据
4. 可以对页面进行局部刷新操作

XMLHttpRequest(异步的与服务器交换数据) 是 Ajax 的基础。

xhr 数据请求流程

  1. 跟昨天介绍的一样,首先是新建一个文件夹(我取的名字是LIANXI),在LIANXI文件夹里新建一个文件夹,名为public,在该文件夹里新建一个文件index.html. 在终端打开LIANXI文件夹,输入npm init ,一直按照默认值点击确认,完成后输入npm install express 安装需要的模块,最后在LIANXI文件夹里新建一个js 文件,名为index.js, 一会服务器上的代码将写在这里。
    这里写图片描述
  2. 先写”客户端”,也就是index.html 中的文件
    XMLHttpRequest 对象用于和服务器交换数据。这里发送数据请求的方式有两种,get和post
与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用
然而,在以下情况中,请使用 POST 请求:
无法使用缓存文件(更新服务器上的文件或数据库)
向服务器发送大量数据(POST 没有数据量限制)
发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

get 请求:

var xhr =  new XMLHttpRequest()
xhr.open('get','/getTest?name=fan&age=18',true);
xhr.send();

post 请求,需要自己设置请求头

var xhr = new XMLHttpRequest()
xhr.open('POST','/postTest',true)
xhr.setRequestHeader("Content-type","application/x-www-form-urlencoded")
xhr.send('num=1&des=我爱你')

在index.html 文件中,有两个button 按钮,分别使用get 和post 方法

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

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>xhr</title>
</head>

<body>
    <button onclick="get()">get方法</button>
    <button onclick="post()">post 方法</button>
    <script>
        function get() {

            var xhr = new XMLHttpRequest()
            // open后面有三个参数:
            // 规定请求的类型、URL 以及是否异步处理请求。
            // method:请求的类型;GET 或 POST
            // url:文件在服务器上的位置
            // async:true(异步)或 false(同步) 默认为true
            xhr.open('get', '/getTest?name=fan&age=18')

            // 发送请求到后端(服务器)
            xhr.send()


            // 当请求被发送到服务器时,我们需要执行一些基于响应的任务。
            // 每当 readyState 改变时,就会触发 onreadystatechange 事件。
            // readyState 属性存有 XMLHttpRequest 的状态信息。
            // 在xhr的准备状态发生改变的时候,调用该方法
            xhr.onreadystatechange = function () {
                if (xhr.readyState == 4 && xhr.status == 200) {
                    console.log(xhr.responseText)
                }
            }
        }

        function post() {
            var xhr = new XMLHttpRequest()
            // post 请求方式,接口后面不能追加参数
            xhr.open('post', '/postTest')

            // 如果使用post 请求方式, 而且是以key=value 这种形式提交的
            // 那么需要设置请求头的类型
            xhr.setRequestHeader('content-type', 'application/x-www-form-urlencoded')
            xhr.send('num=1&des=我爱你')

            xhr.onreadystatechange = function () {
                if (xhr.readyState == 4 && xhr.status == 200) {
                    console.log(xhr.responseText)
                }
            }

        }
    </script>
</body>
</html>

以上代码中,onreadystatechange 事件
当请求被发送到服务器时,我们需要执行一些基于响应的任务。每当 readyState 改变时,就会触发 onreadystatechange 事件。readyState 属性存有 XMLHttpRequest 的状态信息。
总的来说,就是在xhr的准备状态发生改变的时候,调用该方法。 具体值见下表:
这里写图片描述

  1. 写“服务端” 也就是index.js 中的内容
var express = require('express')
var bodyParser = require('body-parser')
var web = express()
web.use(express.static('public'))

// 设置对url 进行编码, 并且不允许url 进行扩展
// 如果设置为False, 那么参数只能为数组或者字符串
// 如果设置为TRUE, 那么参数为任意类型
web.use(bodyParser.urlencoded({extended:false}))

web.get('/getTest', function(req, res){
    var name1 = req.query.name
    var age = req.query.age

    console.log(name1)
    console.log(age)

})

web.post('/postTest', function(req, res){
    var num = req.body.num
    var des = req.body.des
    console.log(num)
    console.log(des)

})

web.listen('8080', function(){
    console.log('服务器启动了')
})

index.js 里的代码比较好理解,至此客户端和服务器端的简单交互就算是完成了,检验一下,
在终端打开LIANXI 文件夹路径,输入node index ,根据我们写的,会提示“程序启动”
我们在浏览器中打开localhost:8080, 如下图所示,点击方框,服务器显示接受数据,表示成功
这里写图片描述

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
XHR 是 XMLHttpRequest 的缩写,它是一种可以在不重新加载整个页面的情况下,通过 JavaScript 发送 HTTP 请求和接收服务器响应的技术。在网页开发中,我们经常会用到 XHR 来实现异步数据交互,比如获取远程数据、发送表单数据等等。 要实现一个简单XHR 请求,我们可以通过以下几个步骤来操作: 1. 创建一个 XMLHttpRequest 对象 2. 指定请求的方法、URL 和是否异步 3. 发送请求 4. 监听 XHR 对象的状态变化,并在接收到响应后处理数据 下面是一个简单的示例代码: ```javascript var xhr = new XMLHttpRequest(); xhr.open('GET', 'https://api.example.com/data', true); xhr.send(); xhr.onreadystatechange = function() { if (xhr.readyState === XMLHttpRequest.DONE) { if (xhr.status === 200) { console.log('成功收到响应:', xhr.responseText); } else { console.log('请求出错:', xhr.status); } } }; ``` 在这个例子中,我们创建了一个 XHR 对象,并使用 GET 方法向 https://api.example.com/data 发送了一个异步请求。然后,我们监听 XHR 对象的状态变化,当 readyState 变为 XMLHttpRequest.DONE 时,表示请求完成。此时我们可以通过 status 属性来判断请求的状态,通过 responseText 属性来获取服务器返回的数据。 总之,XHR 是一种非常有用的技术,可以让我们在网页中实现更加流畅的用户体验,并为用户提供更加丰富的交互功能。希望这个回答能够帮助你更好地了解并使用 XHR

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值