1.XMLHttpResquest的基本使用

1.什么是XMLHttpResquest

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

 1.2 使用 xhr 发起GET请求

步骤:

创建 xhr 对象调用 xhr.open()函数调用 xhr.send()函数监听 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.3了解 xhr 对象的 readyState属性

XMLHttpResquest 对象的 readyState,用来表示 Ajax 请求所处的状态。每个 Ajax请求必然处于以下状态的一个:

值                                状态                   描述

0                              UNSENT                XMLHttpResquest对象已被创建,但尚未调用 open() 方法

1                              OPENED               open()方法已经被调用。

2                              HEADERS_RECEIVED          send() 方法已被调用,响应头已被接收

3                               LOADINC              数据接收中,此时 response 属性已被包含一些数据

4                               DONE                    Ajax请求完成,这意味这数据传输已经切底完成或者失败

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

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

// ...省略不必要的代码

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

// ...省略不必要的代码

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

1.5 查询字符串

1.什么是查询字符串

定义:查询字符串(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=西游记

2.GTE请求携带参数的本质

无论使用$.ajax(),还是使用$.post() ,又或者直接使用 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.6 URL编码与解码

1.什么是 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

2. 如何对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')

// 输出字符串 黑马

3. URL编码的注意事项

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

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

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)

}

}

2.数据交换格式

2.1 什么是数据交换格式

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

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

 2.2 XML

1. 什么是 XML 

XML 的英文是 EXtensible Markup Language , 即 可扩展标记语言。因此,XML 和 HTML 类似,也是一种标记语言。

HTML

  

    Document

  

  

XML

  ls

  zs

  通知

  晚上开会

2. XML 和 HTML 的区别

XML 和 HTML 虽然都是标记语言,但是,他们两者之间没有任何关系。

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

 3. XML 的缺点

  ls

  zs

  通知

  晚上开会

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

2.3 JSON

1. 什么是 JSON

概念:JSON 的英文是 JavaScript Object Notation , 即 ‘ JavaScript ’ 对象表示法。简单来讲,JSON 就是 Javscript 对象和数组的字符串表示法,它使用文本表示一个 JS 对象或数组的信息,因此 JSON 的本质是字符串。

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

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

2. JSON的两种结构

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

2. JSON 的两种结构

对象结构:对象结构在 JSON 表示为 { } 括起来的内容。数据结构为  {  key:value,key:value,....  }的键值对结构。其中,key 必须是使用 英文的双引号包裹 的字符串,value的数据类型可以是 数字、字符串、布尔值、null、数组、对象 6中类型。

{

"name": "zs",

"age": 20,

"gender": "男",

"address": null,

"hobby": ["吃饭", "睡觉", "打豆豆"]

}

数组结构:数组结构在 JSON 中表示为 {  }括起来的内容。数据结构为 [  ” Java “,” JavaScript “ ,30,true ]。

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

[ "java", "python", "php" ]

[ 100, 200, 300.5 ]

[ true, false, null ]

[ { "name": "zs", "age": 20}, { "name": "ls", "age": 30} ]

[ [ "苹果", "榴莲", "椰子" ], [ 4, 50, 5 ] ]

3. JSON 语法注意事项

属性名必须使用双引号包裹字符串类型的值必须使用双引号包裹JSON中不允许使用单引号表示字符串JSON中不能写注释JSON的最外层必须是对象或数组格式不能使用 undefined 或函数作为 JSON 的值

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

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

4. JSON 和 JS 对象的关系

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

//这是一个对象

var obj = {a: 'Hello', b: 'World'}

//这是一个 JSON 字符串,本质是一个字符串

var json = '{"a": "Hello", "b": "World"}'

5. JSON 和 JS 对象的互转

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

var obj = JSON.parse('{"a": "Hello", "b": "World"}')

//结果是 {a: 'Hello', b: 'World'}

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

var json = JSON.stringify({a: 'Hello', b: 'World'})

//结果是 '{"a": "Hello", "b": "World"}'

6.序列化和反序列化

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

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

3.封装自己的 Ajax 函数

3.1 要实现的效果

3.2 定义 options 参数的选项

itheima() 函数是我们自定义的AJax函数,它接收一个配置对象作为参数,配置对象中可以配置如下属性:

method                请求的类型

url                        请求的 url 地址

data                     请求携带的数据

success               请求成功之后的回调函数

3.3 处理 data 函数

需要把 data 对象,转换为查询字符串的格式,从而提交给服务器,因此提前定义 resolveData 函数如下:

/**

 * 处理 data 参数

 * @param {data} 需要发送到服务器的数据

 * @returns {string} 返回拼接好的查询字符串 name=zs&age=10

 */

function resolveData(data) {

  var arr = []

  for (var k in data) {

    arr.push(k + '=' + data[k])

  }

  return arr.join('&')

}

3.4 定义 itheima 函数 

在 itheima ()函数中,需要创建 xhr 对象,并监听 onreadystatechange 事件:

function itheima(options) {

  var xhr = new XMLHttpRequest()

  // 拼接查询字符串

  var qs = resolveData(options.data)

  // 监听请求状态改变的事件

  xhr.onreadystatechange = function() {

    if (xhr.readyState === 4 && xhr.status === 200) {

      var result = JSON.parse(xhr.responseText)

      options.success(result)

    }

  }

}

3.5 判断请求的类型

不同的请求类型,对应 xhr 对象的不同操作,因此需要对请求类型进行 if ... else ... 的判断:

  if (options.method.toUpperCase() === 'GET') {

    // 发起 GET 请求

    xhr.open(options.method, options.url + '?' + qs)

    xhr.send()

  } else if (options.method.toUpperCase() === 'POST') {

    // 发起 POST 请求

    xhr.open(options.method, options.url)

    xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')

    xhr.send(qs)

  }

4.2 XMLHttpRequest Level2 的新特性

4.1 认识XMLRequest的缺点

1.旧版XMLHttpRequest的缺点

只支持文本数据的传输,无法用来读取和上传的文件传送和接收数据时,没有进度信息,只能提示有没有完成

2.XMLHttpRequest Level2的新功能

可以设置 HTTP 的请求时限可以使用 FormData 对象管理表单数据可以上传文件可以获得数据传输的进度信息

4.2 设置 HTTP 请求时限

有时,Ajax 很耗时,而且无法预知要花费多少时间。如果网速很慢,用户可能要等很久。新版本的 XMLHttpRequest 对象,增加了 timeout 属性,可以设置 HTTP 请求的时限:

xhr.timeout = 3000

上面的语句,将最长等待时间设为 3000 毫秒。过来这个时限,就自动会停止 HTTP 请求。与之配套的还有一个 timeout 事件,用来指定回调函数:

xhr.ontimeout = function(event){

alert('请求超时!')

}

4.3 FormData 对象管理表单数据

Ajax 操作往往用来提交表单数据。为了方便表单处理,HTML5 新增一个FormData 对象,可以模拟表单操作:

// 1. 新建 FormData 对象

      var fd = new FormData()

      // 2. 为 FormData 添加表单项

      fd.append('uname', 'zs')

      fd.append('upwd', '123456')

      // 3. 创建 XHR 对象

      var xhr = new XMLHttpRequest()

      // 4. 指定请求类型与URL地址

      xhr.open('POST', 'http://www.liulongbin.top:3006/api/formdata')

      // 5. 直接提交 FormData 对象,这与提交网页表单的效果,完全一样

      xhr.send(fd)

FormData对象也可以用来获取网页表单的值,示例代码如下:

// 获取表单元素

var form = document.querySelector('#form1')

// 监听表单元素的 submit 事件

form.addEventListener('submit', function(e) {

e.preventDefault()

// 根据 form 表单创建 FormData 对象,会自动将表单数据填充到 FormData 对象中

var fd = new FormData(form)

var xhr = new XMLHttpRequest()

xhr.open('POST', 'http://www.liulongbin.top:3006/api/formdata')

xhr.send(fd)

xhr.onreadystatechange = function() {}

})

4.4 上传文件

新版 XMLRequest 对象,不仅可以发送文本信息,还可以上文件

实现步骤:

定义 UI 结构验证是否选择了文件向 FormData 中追加文件使用 xhr 发起了上传文件的请求监听 onreadystatechange 事件

1.定义 UI 结构

    

    

    

    上传文件

    

    

    

2.验证了是否选择了文件

// 1. 获取上传文件的按钮

var btnUpload = document.querySelector('#btnUpload')

// 2. 为按钮添加 click 事件监听

btnUpload.addEventListener('click', function() {

// 3. 获取到选择的文件列表

var files = document.querySelector('#file1').files

if (files.length <= 0) {

return alert('请选择要上传的文件!')

}

// ...后续业务逻辑

})

3. 向 FormData 中追加文件

// 1. 创建 FormData 对象

var fd = new FormData()

// 2. 向 FormData 中追加文件

fd.append('avatar', files[0])

4.使用 xhr 发起上传文件的请求

// 1. 创建 xhr 对象

var xhr = new XMLHttpRequest()

// 2. 调用 open 函数,指定请求类型与URL地址。其中,请求类型必须为 POST

xhr.open('POST', 'http://www.liulongbin.top:3006/api/upload/avatar')

// 3. 发起请求

xhr.send(fd)

5.监听 onreadystatechange 事件

xhr.onreadystatechange = function() {

if (xhr.readyState === 4 && xhr.status === 200) {

var data = JSON.parse(xhr.responseText)

if (data.status === 200) { // 上传文件成功

// 将服务器返回的图片地址,设置为 标签的 src 属性

document.querySelector('#img').src = 'http://www.liulongbin.top:3006' + data.url

} else { // 上传文件失败

console.log(data.message)

}

}

}

4.5 显示文件上传进度

新版本的 XMLHtppRequest 对象中,可以通过监听 xhr.upload.onprogress 事件,来获取到文件的上传进度。语法格式如下:

 // 创建 XHR 对象

var xhr = new XMLHttpRequest()

// 监听 xhr.upload 的 onprogress 事件

xhr.upload.onprogress = function(e) {

// e.lengthComputable 是一个布尔值,表示当前上传的资源是否具有可计算的长度

if (e.lengthComputable) {

// e.loaded 已传输的字节

// e.total 需传输的总字节

var percentComplete = Math.ceil((e.loaded / e.total) * 100)

}

}

1.需要导入的库

    

    

2.基于 bootstrap 渲染进度条

    

    

      

        0%