vue如何实现第三方请求
本文小编为大家详细介绍“vue如何实现第三方请求”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue如何实现第三方请求”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
vue实现第三方请求的方法:1、通过“import axios from 'axios';”导入axios;2、将axios放在原型链上;3、添加请求拦截器,代码如“axios.interceptors.request.use(config => {...}”。
在vue中请求第三方数据--axios
1 axios -> 基于Promise对象 -> async & await
2 create阶段 -> 返回Promise对象 -> 返回的数据可以直接解构【数据处理】
要写入实例的数据(即页面渲染使用的数据),需要用配置参数data接收
3 import axios from 'axios';
4 多次导入、使用的axios -> 将axios放在原型链上
import axios from 'axios';Vue.prototype.axios = axios;
5 请求方法的别名
axios.request(config)
axios.get(url[, config])
axios.delete(url[, config])
axios.head(url[, config])
axios.options(url[, config])
axios.post(url[, data[, config]])
axios.put(url[, data[, config]])
axios.patch(url[, data[, config]])
6 拦截器
// 添加请求拦截器axios.interceptors.request.use(config => { // 在发送请求之前做些什么 return config;}, error => { // 对请求错误做些什么 return Promise.reject(error);});// 添加响应拦截器axios.interceptors.response.use(response => { // 对响应数据做点什么 return response;}, error => { // 对响应错误做点什么 return Promise.reject(error);});
6.1 请求拦截应用
axios.interceptors.request.use(config => { // 在发送请求之前做些什么 let token = sessionStorage.getItem('userTk'); if (token) { config.headers.Authorization = token } return config}, error => { // 对请求错误做些什么 return Promise.reject(error);});
6.2 响应拦截应用
axios.interceptors.response.use(response => { if (response.data.code === '200') { Auth.setToken(sessionStorage.getItem('userId')) } return response;},error => { console.warn(error); console.warn(error.response); if ((error.response.status && error.response.status === 401) || error.response.statusCode === 401) { // 已超时 Auth.removeToken(sessionStorage.getItem('userId')); sessionStorage.clear(); router.replace('/login') return Promise.reject('身份已过期,请重新登录!'); } if(error.response && error.response.status === 500) return Promise.reject('服务异常,请稍后重试!');});
读到这里,这篇“vue如何实现第三方请求”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341