vue axios封装httpjs,接口公用配置拦截操作


Posted in Javascript onAugust 11, 2020

做一下记录,在vue项目中配置公用的请求https,

(1) 位置,在src中新建 src/utils/http.js

import axios from 'axios' // 引用axios
import { MessageBox, Message } from 'element-ui'
import Qs from 'qs' //引入数据格式化
import router from '@/router'
 
// axios 配置
axios.defaults.timeout = 50000 //设置接口响应时间
// axios.defaults.baseURL = 'https://easy-mock.com/mock/' // 这是调用数据接口,公共接口url+调用接口名
let httpUrl = window.location.host
if (httpUrl.indexOf('.com') !== -1) {
 console.log('生产环境', httpUrl)
} else if (httpUrl.indexOf('.net') !== -1) {
 console.log('测试环境', httpUrl)
 axios.defaults.baseURL = 'http://www.test.com' // 这是调用数据接口,公共接口url+调用接口名
} else if (httpUrl.indexOf('localhost:8088') !== -1) {
 console.log('指定开发环境', httpUrl)
 axios.defaults.baseURL = 'http://localhost:8088/'
} else {
 console.log('开发环境', httpUrl)
 axios.defaults.baseURL = 'http://192.168.6.138:8080/' // 这是调用数据接口,公共接口url+调用接口名
}
 
// http request 拦截器,通过这个,我们就可以把Cookie传到后台
axios.interceptors.request.use(
 config => {
  if (config.method == "post") {
  // console.log('请求路径', config.url)
  if (config.url === '/b/login/checkLogin') {
   config.headers = {
    'Content-Type': 'application/x-www-form-urlencoded' // 设置跨域头部
   }
   config.data = Qs.stringify(config.data)
  } else if (config.url === '/b/carModel/createCarModelVersion') {
   // 此处设置文件上传,配置单独请求头
   config.headers = {
    'Content-Type': 'multipart/form-data'
   }
  } else {
   let userInfo = localStorage.getItem('userInfo')
   if (userInfo === null) {
    return null
   }
   let bToken = localStorage.getItem('btoken')
   if (bToken === null) {
   } else {
    config.data.vwToken = bToken
   }
   config.headers = {
    'Content-Type': 'application/x-www-form-urlencoded' // 设置跨域头部
   }
   config.data = Qs.stringify(config.data)
  }
}else{
console.log("get请求")
}
  return config
 },
 err => {
  return Promise.reject(err)
 }
)
 
// http response 拦截器
axios.interceptors.response.use(
 response => {
  // console.log('请求拦截返回参数', response)
  if (response.status === 200) {
   // 成功
   let returnCode = response.data.code
   if (returnCode > 10000 && returnCode < 20000) {
    // console.log('成功', response)
    Message.success(response.data.msg)
   } else if (returnCode >= 20000 && returnCode < 30000) {
    // 只弹窗,不操作
    // console.log('失败1', response)
    Message.error(response.data.msg)
   } else if (returnCode >= 30000 && returnCode < 40000) {
    // 只弹窗,点击跳到登入页
    localStorage.removeItem('userInfo')
 
    MessageBox.confirm(response.data.msg, '确定登出', {
     confirmButtonText: '重新登录',
     cancelButtonText: '取消',
     type: 'warning'
    }).then(() => {
     // console.log('此处应退出登录 重新实例化')
     router.push({ path: '/login' })
    })
   }
  }
  return response
 },
 error => {
  // console.log('error', error.toString())
  if (
   error.toString().trim() ===
   "TypeError: Cannot read property 'cancelToken' of null"
  ) {
   localStorage.removeItem('userInfo')
   MessageBox.confirm(
    '会话凭证失效,可以取消继续留在该页面,或者重新登录',
    '确定登出',
    {
     confirmButtonText: '重新登录',
     cancelButtonText: '取消',
     type: 'warning'
    }
   ).then(() => {
    // console.log('此处应退出登录 重新实例化')
    router.push({ path: '/login' })
   })
  }
 
  // console.log(error.toString().trim())
  if (error.toString().trim() === 'Error: Network Error') {
   MessageBox.alert('网络请求异常,请稍后重试', '出错了', {
    confirmButtonText: '确定',
    callback: action => {}
   })
  }
  return Promise.reject(error.response.data)
 }
)
 
export default axios
 
/**
 * fetch 请求方法
 * @param url
 * @param params
 * @returns {Promise}
 */
export function get(url, params = {}) {
 return new Promise((resolve, reject) => {
  axios
   .get(url, {
    params: params
   })
   .then(response => {
    resolve(response.data)
   })
   .catch(err => {
    reject(err)
   })
 })
}
 
/**
 * post 请求方法
 * @param url
 * @param data
 * @returns {Promise}
 */
export function post(url, data = {}) {
 return new Promise((resolve, reject) => {
  axios.post(url, data).then(
   response => {
    // console.log(response.data.code)
    resolve(response.data)
   },
   err => {
    reject(err)
   }
  )
 })
}
 
/**
 * patch 方法封装
 * @param url
 * @param data
 * @returns {Promise}
 */
export function patch(url, data = {}) {
 return new Promise((resolve, reject) => {
  axios.patch(url, data).then(
   response => {
    resolve(response.data)
   },
   err => {
    reject(err)
   }
  )
 })
}
 
/**
 * put 方法封装
 * @param url
 * @param data
 * @returns {Promise}
 */
export function put(url, data = {}) {
 return new Promise((resolve, reject) => {
  axios.put(url, data).then(
   response => {
    resolve(response.data)
   },
   err => {
    reject(err)
   }
  )
 })
}

(2) 在main.js中引入调用,定义全局

import axios from 'axios'
import { post, get, patch, put } from './utils/http'
 
// 将axios添加到原型链上
Vue.prototype.$axios = axios
 
// 定义全局变量
Vue.prototype.$post = post
Vue.prototype.$get = get
Vue.prototype.$patch = patch
Vue.prototype.$put = put

(3)在需要用到的.vue页面直接使用

//this.logForm 为传参
 
this.logForm = { id: this.selectId, knowledgeVersionId: this.baseValue }
this.$post('你的url', this.logForm).then(req => {
    this.logList = req.data
    this.logList.allCount = req.allCount
    this.logList.nowPage = req.nowPage
    this.logList.pageSize = req.pageSize
    this.loading = false
   }).catch(err => {
    console.log(err)
   })
 
 this.$post('/b/checkConfig/updateRelateKnowledge', { id: this.selectId, knowledgeVersionId: this.baseValue }).then(req => {
    console.log(req)
    if (req.code === 10000) {
     // this.options = req.data
     this.getConfigList()
    }
   }).catch(err => {
    console.log(err)
   })

补充知识:Vue项目关于axios的二次封装service

一、安装axios:npm i axios --save

二、在src目录下新建文件service.js

三、在service.js文件中写入以下代码

import axios from 'axios'

// 创建一个拥有通用配置的axios实例,实例中的配置内容根据实际开发需求而定
export const service = axios.create({
 baseURL: 'http://***.***.*.**:8080/', // 测试环境
 timeout: 1000 * 10, // 请求超时的毫秒数,如果请求花费超过timeout的时间,请求将被中断
 withCredentials: true, // 表示跨域请求时是否需要使用凭证,默认fasle
 headers: { 'Cache-Control': 'no-cache' } // 不允许缓存,需要重新获取请求
})

// 添加请求拦截器
service.interceptors.request.use(config => {
 // 在发送请求之前做些什么
 return config
}, error => {
 // 对请求错误做些什么
 return Promise.reject(error)
})

// 添加响应拦截器
axios.interceptors.response.use(response => {
 // 对响应数据做点什么
 return response
}, error => {
 // 对响应错误做点什么
 return Promise.reject(error)
})

以上是对axios的初步封装,具体功能根据实际需求在service.js文件中进行配置

四、全局使用使用service(也可以局部使用,稍后会说明局部使用方法)

第一步:在main.js中进行挂载

import { service } from './service'

Vue.prototype.service = service

第二步:使用

// 注意:这里必须要使用async 和 await ,不然请求状态一直是Promise {<pending>},拿不到请求数据
 async created () {
  let data = await this.service.get('menu/user/tree')
  console.log(data) //此时能拿到请求的数据
 }

五、局部使用service,在组件内先引入再使用

<script>
import { service } from '../service'
export default {
 name: 'HelloWorld',
 data () {
  return {
   msg: 'sds'
  }
 },
 async created () {
  let data = await service.get('menu/user/tree')
  console.log(data)
 }
}
</script>

以上这篇vue axios封装httpjs,接口公用配置拦截操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 自动增长的文本输入框实现代码
Apr 02 Javascript
js实现的类似于asp数据字典的数据类型代码实例
Sep 03 Javascript
javascript在当前窗口关闭前检测窗口是否关闭
Sep 29 Javascript
jquery实现拖拽调整Div大小
Jan 30 Javascript
jquery实现翻动fadeIn显示的方法
Mar 05 Javascript
基于JavaScript实现动态创建表格和增加表格行数
Dec 20 Javascript
JavaScript获取css行间样式,内连样式和外链样式的简单方法
Jul 18 Javascript
js带闹铃功能的倒计时代码
Sep 29 Javascript
vue 引入公共css文件的简单方法(推荐)
Jan 20 Javascript
判断js数据类型的函数实例详解
May 23 Javascript
vue中element 的upload组件发送请求给后端操作
Sep 07 Javascript
Vue中添加滚动事件设置的方法详解
Sep 14 Javascript
解决vue刷新页面以后丢失store的数据问题
Aug 11 #Javascript
封装 axios+promise通用请求函数操作
Aug 11 #Javascript
在vue中使用回调函数,this调用无效的解决
Aug 11 #Javascript
vue 调用 RESTful风格接口操作
Aug 11 #Javascript
vue之封装多个组件调用同一接口的案例
Aug 11 #Javascript
vue接口请求加密实例
Aug 11 #Javascript
vue组件暴露和.js文件暴露接口操作
Aug 11 #Javascript
You might like
德生PL990,目前市面上唯一一款便携式插卡蓝牙全波段高性能收音机
2021/03/02 无线电
php数字转汉字代码(算法)
2011/10/08 PHP
PHP5.3的垃圾回收机制(动态存储分配方案)深入理解
2012/12/10 PHP
PHP以指定字段为索引返回数据库所取的数据数组
2013/06/30 PHP
php+mysql数据库查询实例
2015/01/21 PHP
php中smarty区域循环的方法
2015/06/11 PHP
PHP实现根据密码长度显示安全条
2017/07/04 PHP
用函数式编程技术编写优美的 JavaScript_ibm
2008/05/16 Javascript
js form 验证函数 当前比较流行的错误提示
2009/06/23 Javascript
window.parent调用父框架时 ie跟火狐不兼容问题
2009/07/30 Javascript
基于JQuery的访问WebService的代码(可访问Java[Xfire])
2010/11/19 Javascript
javascript 基础篇3 类,回调函数,内置对象,事件处理
2012/03/14 Javascript
jQuery 自定义函数写法分享
2012/03/30 Javascript
jQuery中wrapAll()方法用法实例
2015/01/16 Javascript
jQuery和hwSlider实现内容响应式可触控滑动切换效果附源码下载(二)
2016/06/22 Javascript
ros::spin() 和 ros::spinOnce()函数的区别及详解
2016/10/01 Javascript
ReactJs设置css样式的方法
2017/06/08 Javascript
vue 实现v-for循环回来的数据动态绑定id
2019/11/07 Javascript
浅谈Vue.js之初始化el以及数据的绑定说明
2019/11/14 Javascript
使用 UniApp 实现小程序的微信登录功能
2020/06/09 Javascript
Javascript实现鼠标移入方向感知
2020/06/24 Javascript
解决vue项目,npm run build后,报路径错的问题
2020/08/13 Javascript
Vue项目打包编译优化方案
2020/09/16 Javascript
jquery实现抽奖功能
2020/10/22 jQuery
Python3如何解决字符编码问题详解
2017/04/23 Python
Python网络编程 Python套接字编程
2017/09/13 Python
Django实现登录随机验证码的示例代码
2018/06/20 Python
python实现从文件中读取数据并绘制成 x y 轴图形的方法
2018/10/14 Python
python用opencv批量截取图像指定区域的方法
2019/01/24 Python
浅谈Python中threading join和setDaemon用法及区别说明
2020/05/02 Python
Joe Fresh官网:加拿大时尚品牌和零售连锁店
2016/11/30 全球购物
The Body Shop美体小铺西班牙官网:天然化妆品
2019/06/21 全球购物
美国鲜花递送:UrbanStems
2021/01/04 全球购物
信访工作经验交流材料
2014/05/23 职场文书
2015年度高中教师工作总结
2015/05/26 职场文书
2015年大学迎新工作总结
2015/07/16 职场文书