1、axios本身属于Promise
利用函数式的then获取请求返回结果,也是最常用的,如下:
request({ url: '/test/XXX/XXXX', method: 'post', data: param }).then(ret => { if (ret.code === RESULT_CODE.SUCCESS) { this.$message.success('保存成功') } })
此处request对象是对axios做了一层封装,不用在意。此种方式的缺陷是:只能用于请求返回后只有简单操作的情形。
如果返回后的操作比较多,代码就会显得臃肿,可读性差,还有一种情况,即该请求被调用的情况,由于axios没有配置为同步请求的配置项,因此无法直接将上述代码封装后直接调用,因此,引申出第二种方法:
2、async结合await
// api.js文件 // test1方法作为被调用方,被test1方法调用 export async function test1 (param) { // 返回一个Promise对象,真正需要返回给调用方的数据,放在resolve中 return new Promise(resolve => { // request对象是对axios的封装,不用在意 request({ url: '/emr/order/deleteOrder', method: 'post', data: order }).then(ret => { resolve(ret.data) } }) }) }
// VUE文件 methods: { // test2作为调用方调用test1方法 async test2 (param) { const data = await test1(param) } }
3、引入jquery
此处就不写了,这种方式感觉挺没追求的。
在主线程上排队之行的任务,只有在最前面的任务执行完成之后,才之行后面的任务。
(生活中的例子话糙理不怪:银行排队,只有一个窗口的时候,A业务办理完在接着办理B)
是指不进入主线程,而是进入了“任务队列”的任务,只有“任务队列”通知主线程,某个异步任务可执行了,该任务才会进入主线程执行。
(生活中的例子话糙理不怪:多个窗口,可以同时办理业务,互不影响)
异步任务分为:宏任务 微任务
事件执行顺序:
Promise 实现异步调用
asnyc/await 实现同步调用
// 项目中使用的事例:Vue接口请求异步变同步 created() { this.initData(); } methods: { async initData() { let res = await getList(this.params); if (res.message === "成功") { this.resultList = res.data;; } } }
// 异步请求同步的方法 handleClick() { return new Promise((resolve,reject) => { //resolve 成功 ,reject 失败 getRequest().then(res => { //操作1 resolve(); }).catch(error =>{ console.log(error) reject() }) }) }, test(){ Promise.all([this.handleClick()]).then(res=>{ //操作2 }) }
// promise的操作 const promise = new Promise(function(resolve, reject){ if(一步操作成功){ resolve(value); }else{ reject(error); } }) // 异步操作 new Promise((resolve, reject) => { resolve(1); console.log(2); }).then(r => { console.log(r); }); // 2 // 写法一 const promise = new Promise(function(resolve, reject) { try { throw new Error('test'); } catch(e) { reject(e); } }); promise.catch(function(error) { console.log(error); }); // 写法二 const promise = new Promise(function(resolve, reject) { reject(new Error('test')); }); promise.catch(function(error) { console.log(error); });
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。