数据交互——Promise、Ajax、axios和fetch的优缺点

一、Promise

Promise主要用于解决异步回调嵌套的问题。
当多个ajax请求之间存在依赖关系,也就是说一个请求必须使用另一个请求返回的结果时,需要将这个请求嵌套在另一个请求的回调函数上,才能使用另一个请求的结果来发送这个请求。
Promise的思路是将异步请求作为一个对象,将执行成功和失败作为这个对象的方法,执行成功的时候将结果放到这个对象的then方法中处理后续的逻辑,失败调用catch方法。这样调用它就避免了回调函数的嵌套。
使用场景: 主要用于保证多个异步请求都完成以后,再进行后续的业务。

resolve成功状态
reject拒绝状态
then是前面返回promise的处理

Promise的相关概念
es6新语法 用来处理异步编程
promise是一个对象 可以获取异步操作的消息

可以避免多层异步调用嵌套的问题(回调地狱)
提供了简洁的API 使得控制异步操作更加容易
基于promise发送ajax请求

Promise常用的API

1.实例方法
.then() 得到异步任务的正确结果
.catch() 得到异常信息
.finally() 成功与否都会执行

2.对象方法
Promise.all() 并发处理多个异步任务 所有任务都执行完成才能得到结果
Promise.race() 并发处理多个异步任务 只要有一个任务完成就能得到结果

原文链接:https://blog.csdn.net/weixin_43883485/article/details/105142491

二、ajax,fetch,axios优缺点

axios是通过promise实现对ajax技术的一种封装,就像jQuery实现ajax封装一样。

简单来说: ajax技术实现了网页的局部数据刷新,axios实现了对ajax的封装。

axios是ajax ajax不止axios。

1.ajax优缺点

1.本身是针对MVC的编程,不符合现在前端MVVM的浪潮。
2.基于原生的XHR开发,XHR本身的架构不清晰,已经有了fetch的替代方案。
3.JQuery整个项目太大,单纯使用ajax却要引入整个JQuery非常的不合理。
4.不支持back,安全性不高,暴露了与服务端交互的细节。
5.对浏览器的搜索引擎较弱,不会执行js代码,爬虫爬不到,跨域请求有一定的限制。

$.ajax({
   
    type: 'POST',
    url: url,
    d
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值