使用浏览器的XMLHttpRequest对象和服务器进行通信
浏览器网页中,使用Ajax技术(XMLHttpRequest对象)发起获取服务器数据的请求,服务器将数据给前端,前端拿到数据后,展示到网页。
以前前端页面的数据都是写在代码里面固定的,无法随时变化
现在通过Ajax可以动态的从服务器获取,让数据灵活变化
第三方库axios,该库语法简单,让我们有更多精力关注在与服务器通信上,且后续Vue,React,也使用axios库与服务器通信
语法:
- axios({
- url: '目标资源地址',
- method: '请求方法',
- params:{
- 参数名: 值
- }
- }).then((result) => {
- //对服务器返回的数据做后续处理
-
- })
因为普通用户不回去控制台查看服务器传过来的错误信息,所以我们要编写代码拿到错误信息并展示在前端页面上给用户看。
- axios({
- // 请求项
- }).then(result => {
- // 处理成功的数据
- }).catch(error => {
- // 处理失败的错误
- })
参数1:hash
true:收集出来的是一个JS对象结构
false:收集出来的是一个查询字符串格式
参数2:empty
true:收集空的值
false:不收集空置
事件委托,会把一个或者一组元素的事件委托到它的父层或者更外层元素上,真正绑定事件的是外层元素,而不是目标元素。
当事件响应到目标元素上时,会通过事件冒泡机制从而触发它的外层元素的绑定事件上,然后在外层元素上去执行函数。
获取到这次触发事件目标标签元素
直接出线或者隐藏的时候,可以用属性方式来控制。如果需要先执行一段JS逻辑再显示/隐藏就要用JS的方式控制。
先依靠文件选择元素获取用户选择的本地文件,接着提交到服务器保存,服务器会返回图片的url网址,然后把网址加载到img标签的src属性中即可显示图片。
具体:
(1)先获取图片文件对象
(2)使用FormData表单数据对象装入(因为图片是文件而不是以前的数字和字符串,所以传递文件一般需要放入FormData对象中,以 键值对--文件流 的数据结构传递)
- const fd = new FormData()
- fd.append(参数名, 值)
(3)提交表单数据对象,使用服务器返回图片的url地址
Ajax是浏览器与服务器通信的技术,采用XMLHttpRequest对象相关代码。axios是对XHR相关代码进行了封装,让我们只关心传递的接口参数。学习XHR可以了解axios内部与服务器交互过程的真正原理。
- const xhr = new XMLHttpRequest()
- xhr.open('请求方法', '请求url网址')
- xhr.addEventListerner('loadend', () => {
- //响应结果
- console.log(xhr.response)
- })
- xhr.send()
AJAX原理是什么?
window提供的XMLHttpRequest
为什么学习XHR?
有更多与服务器数据通信的方式
XHR的查询参数
XHR的查询参数需要我们自己在url后面携带查询参数字符串,就没有axios帮我们把params参数拼接到url字符串后面了
没有了axios,我们向服务器发送请求时,连请求内容类型都需要我们自己来设置(xhr.setRequestHeader('Content-Type', 'application/json'))
表示(管理)一个异步操作最终状态和结果值的对象
Promise的好处:成功和失败状态,可以各自关联对应的处理函数,并了解到axios内部运作的原理。
语法:
- //1.创建Promise对象
- const p = new Promise((resolve, reject) => {
- // 2.执行异步任务---并传递结果
- // 成功调用: resolve(值)触发then()执行
- // 失败调用: reject(值)触发catch()执行
- })
-
- p.then(result => {
- // 成功
- }).catch(error => {
- // 失败
- })
示例代码:
- const p = new Promise((resolve, reject) => {
- setTimeout(() => {
- // resolve('模拟Ajax请求成功结果')
- reject(new Error('模拟Ajax请求失败结果'))
- }, 2000)
- })
-
- // 获取结果
- p.then(result => {
- console.log(result)
- }).catch(error => {
- console.log(error)
- })
例子:
- // 获取省份数据
- const p = new Promise((resolve, reject) => {
- const xhr = new XMLHttpRequest()
- xhr.open('GET', '服务器省份资源地址')
- xhr.addEventListener('loadend', () => {
- if(xhr.status >= 200 && xhr.status < 300) {
- resolve(JSON.parse(xhr.response))
- } else {
- reject(new Error(xhr.response))
- }
- })
- xhr.send()
- })
-
- p.then(resule => {
- console.log(result)
- document.querySelector('.my-p').innerHTML = result.list.join('
') - }).catch(error => {
- console.log(error)
- document.querySelector('.my-p').innerHTML = error.message
- })
setTimeout,setInterval,事件,AJAX等
依靠回调函数来接收
在回调函数中嵌套回调函数,一直嵌套下去就形成了回调函数地狱
缺点:可读性差,异常无法捕获,耦合性差,牵一发动全身
概念:执行代码和收集异步任务,在调用栈空闲时,反复调用任务队列里回调函数执行机制
为什么有事件循环?
JS是单线程的,为了不阻塞JS引擎,设计执行代码的模型
JS内代码是如何执行的?
执行同步代码,遇到异步代码交给宿主浏览器环境执行。异步代码有了结果后,把回调函数放入任务队列排队,当调用栈空闲后,反复调用任务队列里的回调函数。