vue+axios 对restful 请求封装
礼拜天来公司整理项目,项目是最近开始重构的,里面的各种http请求接口是restful结构的(为了提升项目的比格),整理一下笔记
[restful介绍][1]博主讲的很详细
技术栈: vue + vuex + element-ui + axios
import axios from 'axios'
import store from '../vuex/store'
import { Message } from 'element-ui'
// axios 配置
axios.defaults.timeout = 5000
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8'
axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest'
// POST传参序列化
axios.interceptors.request.use((config) => {
// 单个网站的admin用户
config.headers.common['Gw-Admin-Access-Token'] = store.getters.adminAccessToken
// 整个网点user
config.headers.common['Gw-User-Access-Token'] = store.getters.userAccessToken
return config
}, (err) => {
Message.error('参数错误')
return Promise.reject(err)
})
// 返回状态判断
axios.interceptors.response.use((res) => {
const response = res.data
if (response.msg) {
if (response.code === 0) {
Message.success(response.msg)
} else {
Message.error(response.msg)
}
}
return response
}, (err) => {
if (err && err.response) {
switch (err.response.status) {
case 401:
Message.error('未授权,请登录')
window.location.href = '/#/auth/login'
break
case 404:
Message.error('接口请求异常: ' + err.response.config.url + ', 请重试')
break
default:
Message.error('Oops, 出错啦')
}
}
return Promise.reject(err)
})
export default function request (method, url, data) {
// 处理请求的url和数据
data = method === 'get' ? { params: data } : data
// 发送请求
return new Promise((resolve, reject) => {
axios[method](url, data)
.then(response => {
resolve(response)
}, error => {
reject(error)
})
.catch(error => {
reject(error)
})
})
.catch(error => {
console.log(error)
})
}
封装好的axios请求如下:
1.在相应的api文件中定义方法(如下是goods中的删除商品分类的方法)
delCatList (data) {
return Request('delete', API.GOODS.GOODS_CAT + '/' + data) //其它的操作将对应的delete换成(put、post、get、delete)即可
},
2.在需要的vue界面调用
首先:import Goods from '@/fetch/request/goods'
methods方法:
Goods.addCatList(data).then(res => {
if (res.code === 0) {
console.log(res)
}
})
这里由于封装的时候将axios封装为Promise对象 ,所以可以直接使用.then(),res即为接口返回的结果,代码简介了不少
[Promise对象--阮一峰][2]
总得来说,一次封装,永久收益,哈哈,体验还是不错的,restful的架构风格也是很不错。祝大家周末愉快,杭州下雨:(。。。。
来源:https://segmentfault.com/a/1190000016146893
vue+axios 对restful 请求封装的更多相关文章
- vue axios配置 发起请求加载loading请求结束关闭loading
axios带有请求拦截器,避免在每个请求里面加loading重复操作,可以封装进去,在请求开始时加载loading层,请求结束关闭,loading层用vux的loading加载 axios.js im ...
- vue axios 取消上次请求
axios.defaults.timeout = 1000 * 5axios.defaults.baseURL = baseUrlvar CancelToken = axios.CancelToken ...
- vue --- axios发post请求后台接收不到参数的三种解决方案
最近用vue 做项目使用axios 发送post 请求时遇到了前端传数据后端接收不到的情况: 后来仔细对比发现axios传值是这样的: 而 ajax 传值是这样的: 一个 Request Paylo ...
- Asp.net MVC Vue Axios无刷新请求数据和响应数据
Model层Region.cs using System; using System.Collections.Generic; using System.Linq; using System.Web; ...
- 请求超时VUE axios重新再次请求
//在main.js设置全局的请求次数,请求的间隙 axios.defaults.retry = 4; axios.defaults.retryDelay = 1000; axios.intercep ...
- vue axios 发送post请求,后端接收参数为null
1首先检查自己的传参方式是否正确,我是传一个对象,没有问题,接口也触发了 2查了下资料说是 Content-Type的问题,设置为 'application/x-www-form-urlencod ...
- vue axios拦截器的封装
// request.js import axios from 'axios' import qs from 'qs' // 创建axios实例 const service = axios.creat ...
- Vue axios发送Http请求
axios 1.cnpm install axios --save 2.在vue文件中引入,import Axios from 'axios' 3.使用,Axios.get(url).then((re ...
- vue axios跨域请求,apache服务器设置
问题所在axios请求会发送两次请求 也就是说,它会先使用options去测试,你这个接口是否能够正常通讯,如果不能就不会发送真正的请求过来,如果测试通讯正常,则开始正常请求. 思路: 跨域--> ...
随机推荐
- Leetcode319. Bulb Switcher灯泡开关
初始时有 n 个灯泡关闭. 第 1 轮,你打开所有的灯泡. 第 2 轮,每两个灯泡你关闭一次. 第 3 轮,每三个灯泡切换一次开关(如果关闭则开启,如果开启则关闭).第 i 轮,每 i 个灯泡切换一次 ...
- 系统负载load
一.查看系统负荷 如果你的电脑很慢,你或许想查看一下,它的工作量是否太大了. 在Linux系统中,我们一般使用uptime命令查看(w命令和top命令也行).(另外,它们在苹果公司的Mac电脑上也适用 ...
- Range的范围
range(N,M)的范围应为: [N,M) 例如:
- Ionic 列表、文本 自动 换行
1.采用row 布局的row-warp 来处理 <div class="item item-icon-right"> <span>图片相册</span ...
- springboot核心技术(三)-----web开发
web开发 1.简介 使用SpringBoot: 1).创建SpringBoot应用,选中我们需要的模块: 2).SpringBoot已经默认将这些场景配置好了,只需要在配置文件中指定少量配置就可以运 ...
- [群晖] DSM6.2用winscp通过root权限登录
http://www.nas1.cn/thread-86048-1-1.html 以前DSM6.0的时候可以通过改root密码的方式,来通过winscp来登录nas,这样可以获得最高权限可以任意修改文 ...
- non-identifying and identifying
An identifying relationship means that the child table cannot be uniquely identified without the par ...
- MR过程解析(转自about云)
图中1:表示待处理数据,比如日志,比如单词计数图中2:表示map阶段,对他们split,然后送到不同分区图中3:表示reduce阶段,对这些数据整合处理.图中4:表示二次mapreduce,这个是m ...
- hadoop面试题及答案解析
1.(Datanode)程序负责HDFS数据存储. 2.HDFS中的block默认保存(3份). 3.(TaskTracker)程序通常与NameNode在一个节点启动. 分析:hadoop集群是基于 ...
- NOSQL数据库之 REDIS
NOSQL数据库之 REDIS 一.NOSQL 1.简介 NoSQL ,(Not Only SQL),泛指非关系型数据库. 特点: NoSQL 通常是以key-value形式存储, 不支持SQL语句, ...