ajax学习笔记

AJAX

一、ajax用处

浏览器和服务器之间通信,动态数据交互

二、axios使用语法
  • 引入axios.js:http://cdn.jsdelivr.net/npm/axios/dist/axios.min.js

  • 使用axios函数:

    • 传入配置对象
    • 使用.then回调函数接受结果,并作后续处理
      在这里插入图片描述
三、认识url
1、定义

统一资源定位符,简称网址

2、url组成

在这里插入图片描述

3、url查询参数
  • 定义:浏览器提供给服务器的额外信息,让服务器返回浏览器想要的数据

在这里插入图片描述

  • 语法:

    • 使用axios提供的param选项

    在这里插入图片描述

四、常用请求方法

在这里插入图片描述

1、axios请求配置
  • url
  • method:请求的方法,get可以省略
  • data:提交数据

在这里插入图片描述

五、HTTP响应状态码

在这里插入图片描述

六、HTTP响应报文的组成
  • 响应行:协议、HTTP响应状态码、状态信息
  • 响应头:以键值对的格式携带的附加信息,比如Content-Type
  • 空行:分隔响应头,空行之后的是返回给浏览器的资源
  • 响应体:返回的资源
七、form-serialize插件
  • 作用:快速收集表单元素的值

  • 语法:

在这里插入图片描述

1、注意事项
  • 参数一:要收集哪个表单的数据
    • 表单元素设置name属性,值会作为对象的属性名
    • 建议name属性的值,最好和接口文档参数名一致
  • 参数二:配置对象
    • hash 设置获取数据结构
      • true:JS对象 一般请求体里提交给服务器
      • false:查询字符串
    • empty:设置是否获取空值 推荐获取空值
八、bootstrap弹框使用
1、弹框使用步骤
  • 引入css和js库,且初始不可见
  • 通过自定义属性,控制弹框的显示和隐藏:

在这里插入图片描述

九、图书管理
1、渲染列表

自己的图书数据:给自己起个外号,并告诉服务器,默认会有三本书,基于这三本书做数据的增删改查

  • 方法:
axios({
    url:'……'
    params: {
    creator: '....'
}
})
十、图片上传
  • 获取图片文件对象
  • 使用FormData携带图片文件

在这里插入图片描述

  • 提交表单数据到服务器,使用图片url地址
十一、Promise
1、定义:用于表示异步操作的最终完成(或失败)及其结果值
2、好处:
  • 逻辑更清晰
  • 了解axios函数内部运作
  • 能解决回调函数地狱的问题
3、语法

在这里插入图片描述

4、promise对象三种状态

在这里插入图片描述

十二、同步和异步
1、同步:逐行执行,需原地等待结果后,才继续向下运行
2、异步:调用后耗时,不阻塞代码继续执行(不必原地等待,在将来完成后触发一个回调函数)
十三、回调函数地狱
1、概念:在回调函数中嵌套回调函数,一直嵌套下去就形成了回调函数地狱
2、缺点:可读性差,异常无法捕获,耦合性严重,牵一发而动全身
十四、Promise - 链式调用(可有效解决回调地狱问题)
  • 概念: 依靠then方法会返回一个新生成的Promise对象特性,继续串联下一环任务,直到结束
  • 细节: then()回调函数中的返回值,会影响新生成的Promise对象最终状态和结果
  • 做法: 每个Promise对象中管理一个异步任务,用then返回Promise对象,串联起来

在这里插入图片描述

十五、async函数和await

可以让我们用一种更为简洁的方式写出基于Promise的异步行为而无需可以地链式调用Promise

  • 概念:在async函数内使用await关键字取代then函数,等待获取Promise对象成功状态返回值

在这里插入图片描述

1、捕获错误

try…catch使用

在这里插入图片描述

十六、事件循环
1、概念:JS有一个基于事件循环地并发模型,事件循环负责执行代码、收集和处理事件以及执行队列中的子任务。
2、原因:JS是单线程的,为了让耗时代码不阻塞其他代码运行,设计了事件循环模型
3、执行过程

在这里插入图片描述

  • 执行同步代码,遇到异步代码交给宿主浏览器环境执行
  • 异步有结果后,把回调函数放入任务队列排队
  • 当调用栈空闲后,反复调用任务队列里的回调函数
  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您好!对于学习Ajax,我可以为您提供一些学习笔记。以下是一份简要的Ajax学习笔记,希望对您有所帮助: 1. 什么是Ajax? - Ajax全称为Asynchronous JavaScript and XML(异步JavaScript和XML),是一种用于创建交互式Web应用程序的技术。 - 它通过在后台与服务器进行数据交换,实现在不刷新整个页面的情况下更新部分页面内容。 2. Ajax的优点: - 异步处理:可以在后台发送和接收数据,而无需刷新整个页面。 - 提高用户体验:通过部分更新页面内容,可以提供更快的响应时间和更流畅的用户体验。 - 减轻服务器负担:只更新需要的部分内容,减少了不必要的数据传输和服务器负载。 3. Ajax的基本原理: - 使用XMLHttpRequest对象向服务器发送请求,并接收响应。 - 通过JavaScript在前端处理响应数据。 - 更新页面内容,以显示最新的数据。 4. Ajax的核心技术: - XMLHttpRequest对象:用于与服务器进行数据交换。 - JavaScript:用于处理响应数据和更新页面内容。 - XML或JSON:用于传输数据格式。 5. Ajax的使用步骤: - 创建XMLHttpRequest对象。 - 定义请求类型、URL和是否异步。 - 发送请求并接收响应。 - 处理响应数据并更新页面内容。 6. 常见的Ajax框架和库: - jQuery:一个流行的JavaScript库,提供了简化Ajax开发的方法和函数。 - Axios:一个基于Promise的HTTP客户端,用于浏览器和Node.js。 - Fetch API:一种用于发送和接收网络请求的新标准。 这只是Ajax学习的一些基本概念和步骤,您可以进一步深入学习Ajax的相关知识和实践。希望这些笔记对您有所帮助!如有更多问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值