详解Vue中Axios封装API接口的思路及方法


Posted in Javascript onOctober 10, 2020

一、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接口内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
避免 showModalDialog 弹出新窗体的原因分析
May 31 Javascript
GreyBox技术总结(转)
Nov 23 Javascript
23个Javascript弹出窗口特效整理
Feb 25 Javascript
jquery利用event.which方法获取键盘输入值的代码
Oct 09 Javascript
javascript类型转换使用方法
Feb 08 Javascript
Jquery获取元素的父容器对象示例代码
Feb 10 Javascript
实例讲解JQuery中this和$(this)区别
Dec 08 Javascript
Javascript进制转换实例分析
May 14 Javascript
jquery中的常见问题及快速解决方法小结
Jun 14 Javascript
Mac下安装vue
Apr 11 Javascript
Vue 莹石摄像头直播视频实例代码
Aug 31 Javascript
node.js中对Event Loop事件循环的理解与应用实例分析
Feb 14 Javascript
在Vue中使用Echarts实例图的方法实例
Oct 10 #Javascript
基于Vue.js+Nuxt开发自定义弹出层组件
Oct 09 #Javascript
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
Oct 09 #jQuery
vue中解决chrome浏览器自动播放音频和MP3语音打包到线上的实现方法
Oct 09 #Javascript
vue实现选中效果
Oct 07 #Javascript
electron踩坑之dialog中的callback解决
Oct 06 #Javascript
electron踩坑之remote of undefined的解决
Oct 06 #Javascript
You might like
一个PHP验证码类代码分享(已封装成类)
2011/07/17 PHP
JavaScript实现删除电脑的关机键
2016/07/26 PHP
thinkphp3.2中实现phpexcel导出带生成图片示例
2017/02/14 PHP
浅谈laravel框架与thinkPHP框架的区别
2019/10/23 PHP
laravel框架创建授权策略实例分析
2019/11/22 PHP
为JavaScript类型增加方法的实现代码(增加功能)
2011/12/29 Javascript
JavaScript:Div层拖动效果实例代码
2013/08/06 Javascript
js的延迟执行问题分析
2014/06/23 Javascript
扒一扒JavaScript 预解释
2015/01/28 Javascript
详解JavaScript中this关键字的用法
2016/05/26 Javascript
一步一步封装自己的HtmlHelper组件BootstrapHelper(二)
2016/09/14 Javascript
手机浏览器 后退按钮强制刷新页面方法总结
2016/10/09 Javascript
基于bootstrap页面渲染的问题解决方法
2018/08/09 Javascript
Angular ElementRef简介及其使用
2018/10/01 Javascript
Vue实现滑动拼图验证码功能
2019/09/15 Javascript
[02:43]DOTA2英雄基础教程 圣堂刺客
2013/12/09 DOTA
Python中dictionary items()系列函数的用法实例
2014/08/21 Python
python logging类库使用例子
2014/11/22 Python
Python3学习笔记之列表方法示例详解
2017/10/06 Python
Python 处理图片像素点的实例
2019/01/08 Python
python3发送邮件需要经过代理服务器的示例代码
2019/07/25 Python
python实现数据清洗(缺失值与异常值处理)
2019/12/02 Python
Python生成词云的实现代码
2020/01/14 Python
logging level级别介绍
2020/02/21 Python
荷兰本土平价百货:HEMA
2017/10/23 全球购物
联想香港官方网站及网店:Lenovo香港
2018/04/13 全球购物
Melissa鞋英国官方网站:Nonnon
2019/05/01 全球购物
Coccinelle官网:意大利的著名皮具品牌
2019/05/15 全球购物
土木工程毕业生自荐信
2013/11/12 职场文书
入党积极分子自我鉴定
2014/02/18 职场文书
个人三严三实对照检查材料思想汇报
2014/09/22 职场文书
批评与自我批评总结
2014/10/17 职场文书
预备党员转正材料
2014/12/19 职场文书
大学开学典礼新闻稿
2015/07/17 职场文书
8g内存用python读取10文件_面试题-python 如何读取一个大于 10G 的txt文件?
2021/05/28 Python
idea搭建可运行Servlet的Web项目
2021/06/26 Java/Android