一、axios的封装
在vue项目中,和后台交互获取数据这块,我们通常使用的是axios库,它是基于promise的http库,可运行在浏览器端和node.js中。他有很多优秀的特性,例如拦截请求和响应、取消请求、转换json、客户端防御XSRF等。
在一个项目中我们如果要使用很多接口的话,总不能在每个页面都写满了.get()或者.post()吧?所以我们就要自己手动封装一个全局的Axios网络模块,这样的话就既方便也会使代码量不那么冗余。
安装
> npm install axios //这个就是安装axios的命令
首先我们要现在项目中安装Axios组件,这一步是一定的。
下载好了以后,就在项目的src文件里再新建两个目录,一个是http,一个是api。http目录是用来封装Axios的,api目录是用来统一来管理我们的接口的。
引入
第一步,先要在http.js里面引入axios
import axios from 'axios'
环境的切换
在我们开发项目的时候会有多种环境,就比如开发环境、测试环境、生产环境,使用axios.defaults.baseURL可以设置axios的默认请求地址。
//在开发环境中的测试 development if(process.env.NODE_ENV == 'development') { axios.defaults.baseURL = 'http://120.53.31.103:84/' } //在生产环境中的测试 production if(process.env.NODE_ENV == 'production') { axios.defaults.baseURL = 'https://wap.365msmk.com/' } //还有一种环境 debug
设置响应超时时间
通过axios.defaults.timeout设置默认的请求超时时间。如果超出了响应时间,就会告知用户当前请求超时,请刷新等等
//响应超时的时间 axios.defaults.timeout = 5000;
设置接口请求拦截
//接口请求拦截 axios.interceptors.request.use( config => { config.headers = { DeviceType : 'H5' } //设置响应头部 return config } )
使用promise返回axios请求的结果
post :
export function get(url,params){ return new Promise((resolve,reject) => { axios.get(url,{ params : params }).then(res => { resolve(res) }).catch(err => { reject(err) }) }) }
get :
export function post(url,params){ return new Promise((resolve,reject) => { axios.post(url,params) .then(res => { resolve(res.data) }) .catch(err => { reject(err.data) }) }) }
这个时候,http.js里面的就写好了。下面就要去api.js去获取api接口了。
现在是api.js中的内容
首先是要在api.js中引入刚刚封装好的axios
import {get,post} from '../http/http.js' //get post 同时都要引入
然后就可以根据接口文档来进行数据的获取啦
//封装接口的方法 export function getAppIndex() { return get('api/app/recommend/appIndex') } export function getBanner() { return get('api/app/banner') } export function getTel() { return post('api/app/smsCode',{ //这里用的是params传参,直接写{}就可,不用再声明params啦 mobile : 18567391972, sms_type : 'login' }) }
再再然后,就可以去vue页面通过生命周期来获取数据啦。
再再再注意,这里不一定一定要使用async函数,这只是其中一种方法啦
async mounted() { // 明星讲师、精品课程等等 let res = await getAppIndex(); //添加到数组 this.startList = res.data.data.list // 轮播图列表 var banner = await getBanner(); // console.log('轮播图'+ banner) if (banner.data.code == 200) { this.bannerList = banner.data.data } // 手机验证码接口 let Tel = await getTel(); // console.log('手机验证码'+ Tel) // },
到此这篇关于详解Vue中Axios封装API接口的思路及方法的文章就介绍到这了,更多相关Vue Axios封装API接口内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍vue中Axios的封装与API接口的管理详解,包括了vue中Axios的封装与API接口的管理详解的使用技巧和注意事项,需要的朋友参考一下 如图,面对一团糟代码的你~~~真的想说,What F~U~C~K!!! 回归正题,我们所要的说的axios的封装和api接口的统一管理,其实主要目的就是在帮助我们简化代码和利于后期的更新维护。 一、axios的封装 在vue项目中,和后台交互获
本文向大家介绍vue axios 简单封装以及思考,包括了vue axios 简单封装以及思考的使用技巧和注意事项,需要的朋友参考一下 axios 简介 axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,它本身具有以下特征: --------------------------------------------------------------------
本文向大家介绍详解vue中axios的使用与封装,包括了详解vue中axios的使用与封装的使用技巧和注意事项,需要的朋友参考一下 分享下我自己的axios封装 axios是个很好用的插件,都是一些params对象,所以很方便做一些统一处理 当然首先是npm安装axios 很简单$ npm install axios --save 在src下新建文件夹 service / index.js 接着上
本文向大家介绍Vue二次封装axios为插件使用详解,包括了Vue二次封装axios为插件使用详解的使用技巧和注意事项,需要的朋友参考一下 照例先贴上 axios 的 gitHub 地址 不管用什么方式获取数据,对于一个项目来说,代码一定要利于维护其次是一定要写的优美,因此加上一层封装是必要的 vuejs2.0 已经不再维护 vue-resource,vuejs2.0 已经使用了 axios,这也
本文向大家介绍vue中axios的二次封装实例讲解,包括了vue中axios的二次封装实例讲解的使用技巧和注意事项,需要的朋友参考一下 我们做项目时,虽然axios也可以直接拿来用,但是对接口比较零散,不太好进行维护,也会产生大量的重复代码,所以我在这对axios进行了统一接口处理 第一步,先在src中的公共文件夹中如utils里新建request.js文件 代码解读: 将接口统一放到单独的文
在Vue的一些开源框架中,我发现很多有封装了axios,但是我有个疑问,如果不是封装的话,调用路径参数一般是这样的: 就是说get请求的https://api.spacexdata.com/v4/capsules/,附加了路径参数62615d180ec008379be596f1,是直接拼到后面的,而对于如vue-element-admin,他们的 封装是这样的: 我没有看到任何将params: {