1.async/await场景

这是一个用同步的思维来解决异步问题的方案,当前端接口调用需要等到接口返回值以后渲染页面时。

2.名词解释

>async

async的用法,它作为一个关键字放到函数前面,用于表示函数是一个异步函数,因为async就是异步的意思, 异步函数也就意味着该函数的执行不会阻塞后面代码的执行,async 函数返回的是一个promise 对象。

>await

await的含义为等待。意思就是代码需要等待await后面的函数运行完并且有了返回结果之后,才继续执行下面的代码。这正是同步的效果

>例子

function fn() { 

    return new Promise((resolve, reject) => { 

        setTimeout(() => { 

            reject(hello vue.js'); 

        }, 1000); 

    }) 

} 

const foo = async () => { 

    try { 

        await fn(); 

    } catch (e) { 

        console.log(e);  // some error 

    } 

} 

3.案例

auth.vue

需要注意:await必须放在async中

  import http from '../../utils/http'
import api from '../../utils/api' methods: {
fetchData: async function () {
var that = this
var code = Store.fetchYqm();
let params = {
inviteCode: code
}
const response = await http.post(params,api.getCode)
var resJson = response.data; }
}

http.js

'use strict'

import axios from 'axios'
import qs from 'qs' axios.interceptors.request.use(config => {
// loading
return config
}, error => {
return Promise.reject(error)
}) axios.interceptors.response.use(response => {
return response
}, error => {
return Promise.resolve(error.response)
}) function checkStatus (response) {
// loading
// 如果http状态码正常,则直接返回数据
if (response && (response.status === 200 || response.status === 304 || response.status === 400)) {
return response
// 如果不需要除了data之外的数据,可以直接 return response.data
}
// 异常状态下,把错误信息返回去
return {
status: -404,
msg: '网络异常'
}
} function checkCode (res) {
// 如果code异常(这里已经包括网络错误,服务器错误,后端抛出的错误),可以弹出一个错误提示,告诉用户
if (res.status === -404) {
alert(res.msg)
}
if (res.data && (!res.data.success)) {
alert(res.data.error_msg)
}
return res
} export default {
post (data,url) {
return axios({
method: 'post',
url: url,
data: qs.stringify(data),
timeout: 10000,
headers: {
'X-Requested-With': 'XMLHttpRequest',
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
}
}).then(
(response) => {
return checkStatus(response)
}
)
},
get (url, params) {
return axios({
method: 'get',
baseURL: 'https://cnodejs.org/api/v1',
url,
params, // get 请求时带的参数
timeout: 10000,
headers: {
'X-Requested-With': 'XMLHttpRequest'
}
}).then(
(response) => {
return checkStatus(response)
}
).then(
(res) => {
return checkCode(res)
}
)
}
}

api.js

export default {
getCode: 'http://127.0.0.1:8888/get_author'
}

最新文章

  1. asp.net 无法加载程序集***
  2. 玩玩redis
  3. 异常处理try-catch-finally
  4. Mysql基本数据操作
  5. eclipse JAVA 类元素 快速添加set和get方法
  6. FreeMarker笔记 第四章 其它
  7. RPC进阶篇
  8. Python 连接mysql
  9. Python强大的自省简析
  10. FZU 1058 粗心的物理学家
  11. 常见dos命令总结
  12. Android Service基础
  13. 实验吧_who are you?(盲注)
  14. [转] Webpack 打包优化之体积篇
  15. VBA二次学习笔记(1)——文件操作
  16. centos7安装node
  17. Markdown图片存储解决方法-利用阿里云OSS
  18. snort安装使用教程(CentOS6.5)
  19. tomcat服务的启动与隐藏启动(win)
  20. webpack4 自学笔记五(tree-shaking)

热门文章

  1. 谷歌旗下专业图片编辑Snapseed获重大更新
  2. MFC数据库操作
  3. 第二节:Java开发环境的搭建
  4. spring boot入门笔记 (三) - banner、热部署、命令行参数
  5. db2存储过程迁移
  6. webpack开发工具
  7. react知识点汇总
  8. OpenGL学习--05--纹理立方体--代码
  9. FineReport中如何实现自动滚屏效果
  10. 带你从零学ReactNative开发跨平台App开发-[react native 仿boss直聘](十三)