Ajax第三天笔记总结(一)

简介: Ajax第三天笔记总结(一)

一、XMLHttpRequest 基本使用

1、什么是 XMLHttpRequest

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


2、使用 xhr 发起 GET 请求

步骤:

  • 创建 xhr 对象
  • 调用 xhr.open() 函数
  • 调用 xhr.send() 函数
  • 监听 xhr.onreadystatechange 事件


代码:

// 1. 创建 XHR 对象
    const xhr = new XMLHttpRequest()
    console.log(xhr);
    // 2. 调用 open 函数
    //open函数接收两个参数,一个是请求类型,一个是接口地址
    xhr.open('GET','http://www.liulongbin.top:3006/api/getbooks')
    // 3. 调用 send 函数
    xhr.send()
    // 4. 监听 onreadystatechange 事件
    xhr.onreadystatechange = function(){
      console.log(xhr.readyState);
      //当xhr的readyState为4,status为200的时候意味着请求成功
      if(xhr.readyState === 4 && xhr.status === 200){
        console.log(xhr.responseText);
      }
    }


3、xhr 的 readyState 属性

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


状态 描述
0 UNSENT XMLHttpRequest 对象已被创建,但尚未调用 open 方法
1 OPENED open() 方法已经被调用
2 HEADERS_RECEIVED Send() 方法已经被调用,响应头也已经被接收
3 LOADING 数据接收中,此时 response 属性中已经包含部分数据
4 DONE Ajax 请求完成,这意味着数据传输已经彻底 完成 或 失败


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

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

xhr.open("GET", "http://www.liulongbin.top:3006/api/getbooks?id=1");


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

代码:

var xhr = new XMLHttpRequest();
xhr.open("GET", "http://www.liulongbin.top:3006/api/getbooks?id=1");
xhr.send();
xhr.onreadystatechange = function() {
  if( xhr.readyState == 4 && xhr.status == 200) {
    console.log(xhr.responseText);
  }
}



5、查询字符串
  • 什么是查询字符串
    定义查询字符串(URL 参数)是指在 URL 的末尾加上用于向服务器发送信息的字符串(变量)
  • 格式:将英文的 ? 放在URL 的末尾,然后再加上 参数=值 ,想加上多个参数的话,使用 & 符号进行分隔。以这个形式,可以将想要发送给服务器的数据添加到 URL 中。

716cf6a234e44a6bb7dbca170e624a87.png


  • GET请求携带参数的本质

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

2a394447e8aa4e25adb8986319971539.png


6、URL编码与解码
  • 什么是URL编码
    URL 地址中,只允许出现英文相关的字母、标点符号、数字,因此,在 URL 地址中不允许出现中文字符。

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

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

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

7e0105f1df2242f39db856970e754dc0.png


  • 如何对URL进行编码与解码浏览器提供了URL编码与解码的API,分别是:
  • encodeURI() 编码的函数
  • decodeURI() 解码的函数
encodeURI('巨人的小脚丫')
'%E5%B7%A8%E4%BA%BA%E7%9A%84%E5%B0%8F%E8%84%9A%E4%B8%AB'
decodeURI('%E5%B7%A8%E4%BA%BA')
'巨人'


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

更多关于 URL 编码的知识,请参考如下博客:https://blog.csdn.net/Lxd_0111/article/details/78028889


7、使用 xhr 发起 POST 请求

步骤:

  • 创建 xhr 对象
  • 调用 xhr.open() 函数
  • 设置 Content-Type 属性(固定写法)
  • 调用 xhr.send() 函数,同时指定要发送的数据
  • 监听 xhr.onreadystatechange 事件


代码:

 // 1. 创建 xhr 对象
const 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. 监听事件
xhr.onreadystatechange = function () {
  if (xhr.readyState === 4 && xhr.status === 400) {
    console.log(xhr.responseText);
  }
};


二、数据交换格式

1、什么是数据交换格式

数据交换格式,就是 服务器端客户端 之间进行 数据传输与交换的格式

前端领域,经常提及的两种数据交换格式分别是 XMLJSON。其中 XML 用的非常少,所以,我们重点要学习的数据交换格式就是 JSON

dc8ea9b3985f4168a05b7533469dc4e6.png


2、XML
  • 什么是XML
    XML 的英文全称是 EXtensible Markup Language,即可扩展标记语言。因此,XMLHTML 类似,也是一种标记语言。

56b36eb204ee4ce4a17d17a68f190f85.png


XML和HTML的区别

XMLHTML 虽然都是标记语言,但是,它们两者之间没有任何的关系。

  • HTML 被设计用来描述网页上的内容,是网页内容的载体
  • XML 被设计用来传输和存储数据,是数据的载体

e7b66a5279044b859b287999304489b3.png

  • XML的缺点
  • XML 格式臃肿,和数据无关的代码多,体积大,传输效率低
  • Javascript 中解析 XML 比较麻烦


3、JSON
  • 什么是 JSON
    概念:JSON 的英文全称是 JavaScript Object Notation,即“JavaScript 对象表示法”。简单来讲,

JSON 就是 Javascript 对象和数组的字符串表示法,它使用文本表示一个 JS 对象或数组的信息,因此,JSON 的本质是字符串

作用:JSON 是一种轻量级的文本数据交换格式,在作用上类似于 XML,专门用于存储和传输数据,但是 JSONXML 更小、更快、更易解析。

现状:JSON 是在 2001 年开始被推广和使用的数据格式,到现今为止,JSON 已经成为了主流的数据交换格式


  • JSON 的两种结构
    JSON 就是用字符串来表示 Javascript 的对象和数组。所以,JSON 中包含 对象数组 两种结构,通过这两种结构的相互嵌套,可以表示各种复杂的数据结构。


  • 对象结构

对象结构在 JSON 中表示为 { } 括起来的内容。数据结构为 { key: value, key: value, … } 的键


值对结构。其中,key 必须是使用英文的双引号包裹的字符串,value 的数据类型可以是 数字、字符串、布尔值、null、数组、对象 6种类型。

08e18a7829374e1db35883a43167273e.png


  • 数组结构

数组结构在 JSON 中表示为 [ ] 括起来的内容。数据结构为 [ "java", "javascript", 30, true … ]

数组中数据的类型可以是数字、字符串、布尔值、null、数组、对象6种类型。

452ae49cefe746ddaa79bb2ee10a6e77.png


JSON 语法注意事项

① 属性名必须使用双引号包裹

② 字符串类型的值必须使用双引号包裹

JSON 中不允许使用单引号表示字符串

JSON 中不能写注释

JSON 的最外层必须是对象或数组格式

⑥ 不能使用 undefined 或函数作为 JSON 的值

JSON 的作用:在计算机与网络之间存储和传输数据。

JSON 的本质:用字符串来表示 Javascript 对象数据或数组数据


  • JSON 和 JS 对象的关系

JSONJS 对象的字符串表示法,它使用文本表示一个 JS 对象的信息,本质是一个字符串。例如:

a1d941018124422282ca46e6d561e182.png


  • JSON 和 JS 对象的互转

要实现从 JSON 字符串转换为 JS 对象,使用 JSON.parse() 方法:

代码:

let obj = JSON.parse('{"a": "Hello", "b": "World"}')
// 结果 {a: "Hello", b: "World"}


要实现从 JS 对象转换为 JSON 字符串,使用 JSON.stringify() 方法:

代码:

let json = JSON.stringify({a: "Hello", b: "World"})
// 结果 '{"a": "Hello", "b": "World"}'


应用场景:

const xhr = new XMLHttpRequest()
xhr.open('GET', 'http://www.liulongbin.top:3006/api/getbooks')
xhr.send()
xhr.onreadystatechange = function () {
  if (xhr.readyState === 4 && xhr.status === 200) {
    console.log(xhr.responseText)
    console.log(typeof xhr.responseText)
    var result = JSON.parse(xhr.responseText)
    console.log(result)
  }
}


4、序列化和反序列化

数据对象转换为字符串 的过程,叫做 序列化,例如:调用 JSON.stringify() 函数的操作,叫做 JSON 序列化。

字符串 转换为 数据对象 的过程,叫做 反序列化,例如:调用 JSON.parse() 函数的操作,叫做 JSON 反序列化。








目录
相关文章
|
6月前
|
JSON 前端开发 JavaScript
AJAX 课程学习笔记三
AJAX 课程学习笔记三
|
5月前
|
JSON 前端开发 JavaScript
前端Ajax、Axios和Fetch的用法和区别笔记
前端Ajax、Axios和Fetch的用法和区别笔记
97 2
|
前端开发 数据可视化 JavaScript
Python Flask Echarts数据可视化图表实战晋级笔记(4)ajax参数传递互动
Python Flask Echarts数据可视化图表实战晋级笔记(4)ajax参数传递互动
126 0
|
6月前
|
JSON 缓存 前端开发
AJAX 课程学习笔记二
AJAX 课程学习笔记二
|
6月前
|
XML 前端开发 JavaScript
AJAX 课程学习笔记一
AJAX 课程学习笔记一
|
6月前
|
JSON 前端开发 JavaScript
前端知识笔记(三十七)———Django与Ajax
前端知识笔记(三十七)———Django与Ajax
54 0
|
6月前
|
XML JSON 前端开发
Ajax后端极简笔记
Ajax后端极简笔记
71 0
|
6月前
|
JSON 前端开发 JavaScript
前端知识笔记(二)———Django与Ajax
前端知识笔记(二)———Django与Ajax
61 0
|
前端开发
前端学习笔记202306学习笔记第四十三天-ajax的经典四大步骤3
前端学习笔记202306学习笔记第四十三天-ajax的经典四大步骤3
73 0
|
前端开发
前端学习笔记202306学习笔记第四十三天-ajax的经典四大步骤1
前端学习笔记202306学习笔记第四十三天-ajax的经典四大步骤1
63 0