• Ajax零基础入门 Ajax零基础入门第三天 3.1 XMLHttpRequest的基本使用


    Ajax零基础入门

    Ajax零基础入门第三天

    老师:黑马程序员

    3. Ajax加强

    3.1 XMLHttpRequest的基本使用
    3.1.1 什么是XMLHttpRequest

    XMLHttpRequest(简称xhr)是浏览器提供的Javascript对象,通过它,可以请求服务器上的数据资源。之前所学的 jQuery中的Ajax函数,就是基于xhr对象封装出来的。

    在这里插入图片描述

    3.1.2 使用xhr发起GET请求

    步骤:

    ①创建 xhr 对象

    ②调用 xhr.open() 函数

    ③调用 xhr.send() 函数

    ④监听 xhr.onreadystatechange 事件

    // 1. 创建 XHR 对象
    var xhr = new XMLHttpRequest()
    // 2. 调用 open 函数,指定 请求方式 与 URL地址
    xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks')
    // 3. 调用 send 函数,发起 Ajax 请求
    xhr.send()
    // 4. 监听 onreadystatechange 事件
    xhr.onreadystatechange = function() {
        // 4.1 监听 xhr 对象的请求状态 readyState ;与服务器响应的状态 status
        if (xhr.readyState === 4 && xhr.status === 200) {
            // 4.2 打印服务器响应回来的数据
            console.log(xhr.responseText)
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    3.1.3 了解xhr对象的readyState属性

    XMLHttpRequest对象的readyState属性,用来表示当前 Ajax 请求所处的状态。每个 Ajax请求必然处于以下状态中的一个:

    在这里插入图片描述

    3.1.4 使用xhr发起带参数的GET请求

    使用xhr对象发起带参数的GET请求时,只需在调用xhr.open期间,为URL地址指定参数即可:

    // ...省略不必要的代码
    xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks?id=1')
    // ...省略不必要的代码
    
    • 1
    • 2
    • 3

    这种在 URL 地址后面拼接的参数,叫做查询字符串

    3.1.5 查询字符串

    【什么是查询字符串】

    定义:查询字符串(URL 参数)是指在 URL 的末尾加上用于向服务器发送信息的字符串(变量)。

    格式:将英文的 ? 放在URL 的末尾,然后再加上 参数=值 ,想加上多个参数的话,使用 & 符号进行分隔。以这个形式,可以将想要发送给服务器的数据添加到 URL 中。

    // 不带参数的 URL 地址
    http://www.liulongbin.top:3006/api/getbooks
    // 带一个参数的 URL 地址
    http://www.liulongbin.top:3006/api/getbooks?id=1
    // 带两个参数的 URL 地址
    http://www.liulongbin.top:3006/api/getbooks?id=1&bookname=西游记
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    【GET请求携带参数的本质】无论使用 . a j a x ( ) ,还是使用 .ajax(),还是使用 .ajax(),还是使用.get(),又或者直接使用xhr对象发起GET请求,当需要携带参数的时候,本质上,都是直接将参数以查询字符串的形式,追加到URL地址的后面,发送到服务器的。

    $.get('url', {name: 'zs', age: 20}, function() {})
    // 等价于
    $.get('url?name=zs&age=20', function() {})
    
    $.ajax({ method: 'GET', url: 'url', data: {name: 'zs', age: 20}, success: function() {} })
    // 等价于
    $.ajax({ method: 'GET', url: 'url?name=zs&age=20', success: function() {} })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    3.1.6 URL编码和解码

    【什么是URL编码】

    URL 地址中,只允许出现英文相关的字母、标点符号、数字,因此,在 URL 地址中不允许出现中文字符。

    如果 URL 中需要包含中文这样的字符,则必须对中文字符进行编码(转义)。

    URL编码的原则:使用安全的字符(没有特殊用途或者特殊意义的可打印字符)去表示那些不安全的字符。

    URL编码原则的通俗理解:使用英文字符去表示非英文字符。

    http://www.liulongbin.top:3006/api/getbooks?id=1&bookname=西游记
    // 经过 URL 编码之后,URL地址变成了如下格式:
    http://www.liulongbin.top:3006/api/getbooks?id=1&bookname=%E8%A5%BF%E6%B8%B8%E8%AE%B0
    
    • 1
    • 2
    • 3

    【如何对URL进行编码与解码】

    浏览器提供了 URL 编码与解码的 API,分别是:

    encodeURI() 编码的函数

    decodeURI() 解码的函数

    encodeURI('黑马程序员')
    // 输出字符串  %E9%BB%91%E9%A9%AC%E7%A8%8B%E5%BA%8F%E5%91%98
    decodeURI('%E9%BB%91%E9%A9%AC')
    // 输出字符串  黑马
    
    • 1
    • 2
    • 3
    • 4

    【URL编码的注意事项】

    由于浏览器会自动对URL地址进行编码操作,因此,大多数情况下,程序员不需要关心URL地址的编码与解码操作。

    3.1.7 使用xhr发起POST请求

    步骤:

    ①创建 xhr 对象

    ②调用 xhr.open() 函数

    设置 Content-Type 属性(固定写法)

    ④调用 xhr.send() 函数,同时指定要发送的数据

    ⑤监听 xhr.onreadystatechange 事件

    // 1. 创建 xhr 对象
    var xhr = new XMLHttpRequest()
    // 2. 调用 open()
    xhr.open('POST', 'http://www.liulongbin.top:3006/api/addbook')
    // 3. 设置 Content-Type 属性(固定写法)
    xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')
    // 4. 调用 send(),同时将数据以查询字符串的形式,提交给服务器
    xhr.send('bookname=水浒传&author=施耐庵&publisher=天津图书出版社')
    // 5. 监听 onreadystatechange 事件
    xhr.onreadystatechange = function() {
        if (xhr.readyState === 4 && xhr.status === 200) {
            console.log(xhr.responseText)
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
  • 相关阅读:
    Netty之数据解码
    三百六十行行行出状元之短视频入门必备技巧——配音
    SSM+MySQL+JSP教务管理系统设计与实现(附源码下载地址)
    Postgresql在jdbc处理bit字段的解决方案
    Pytorch入门笔记
    CSS3技巧36:backdrop-filter 背景滤镜
    [自制操作系统] 第07回 认识保护模式之地址映射
    成电少年学fpga培训就业班怎么样
    摄像头工程师说 Camera-如何控制摄像头的输出尺寸(分辨率)
    【刷题学习Java】——循环语句
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/126717513