Vue.js(18)之 axios简单封装
基于vue-cli2.x封装axios
src目录

axios.js
import axios from 'axios'
import { Indicator, Toast } from 'mint-ui'
// request 拦截器
axios.interceptors.request.use(config => {
Indicator.open({ text: '加载中...', spinnerType: 'snake' })
return config
}, err => {
Indicator.close();
Toast({ message: '请检查您的网络连接并重试', duration: 2000, className: 'mToast' })
return Promise.reject(err)
})
// response 拦截器
axios.interceptors.response.use(
config => {
Indicator.close();
return config
}, err => {
Indicator.close();
Toast({ message: '请检查您的网络连接并重试', duration: 2000 })
Promise.reject(err)
}
)
export default axios
config.js
// 在 axios中,利用QS包装data数据
import Qs from 'qs'
const config = {
baseURL: 'http://www.****.top:8888/',
url: '',
method: 'get',
params: {},
data: {},
timeout: 100000,
withCredentials: false,
responseType: 'json',
headers: {
'Content-Type': 'application/json'
},
maxContentLength: 10000,
maxRedirects: 5,
transformResponse: [function(data) {
return data
}],
paramsSerializer: function(params) {
return Qs.stringify(params)
},
onUploadProgress: function(progressEvent) {
// console.log('onUploadProgress...');
},
onDownloadProgress: function(progressEvent) {
// console.log('onDownloadProgress...');
}
}
export default config
fetch.js
// 引入 请求拦截 配置
import $axios from "./axios"
// 引入 请求参数 配置
import config from './config'
config.headers.Authorization = window.sessionStorage.getItem('token') || ''
// 封装成自己的方法
fetch = async function(url, method, request, other) {
let response
if(method == 'post') {
config.data = request
response = await $axios.post(url, request, config)
} else if(method == 'get') {
config.params = request
response = await $axios.get(url, config)
}
console.log(response)
return response
}
export default fetch
测试

.vue文件
<template>
<div>
<hr>
<h1 @click="postJson">login-postJson</h1>
<hr>
<h1 @click="getJson">getJson</h1>
<hr>
<h1 @click="getUserList">getUserList</h1>
</div>
</template>
<script>
import mix from './Apitest-mixins.ts'
export default {
mixins: [mix]
}
</script>
.ts文件
import fetch from '../../request/fetch.js'
export default {
methods: {
async postJson() {
const params = {
"username": "admin",
"password": "123456"
}
let { data: res } = await fetch('/login', 'post', params)
window.sessionStorage.setItem('token', res.data.token)
console.log(res)
},
async getJson() {
let { data: res } = await fetch('/roles', 'get')
console.log(res)
},
async getUserList() {
let params = {
query: 'a',
pagenum: 2,
pagesize: 10
}
const { data: res } = await fetch('/users', 'get', params )
console.log(res)
}
}
}

遗留bug
请求头???百度了2天,问了同事也没有解决了,自己都奔溃了

Vue.js(18)之 axios简单封装的更多相关文章
- axios简单封装
写在最前面 新手前端刚刚接触vue,感觉真的好用.项目中需要使用axios,然后学习了一下.借鉴网上一些大佬的经验,现在分享一下axios的简单封装,如果有什么错误的地方,请大家指出. axios安装 ...
- Vue.js的安装及简单使用
一.Vue简介 二.Vue.js的安装 2.1.npm安装 2.1.1.node.js介绍及安装 简介: 简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是一个基 ...
- vue-axios当只调用vue.js又需要axios请求多时
可以将axios方法封装一个函数 (function () { ASK = { get:function (url,data,succFun,errFun) { axios.get(url,{ par ...
- vue axios 简单封装以及思考
先安装 axios npm install axios axios的详细介绍以及用法 就不多说了请 移步 github ➡️ https://github.com/axios/axios 下面是简单 ...
- vue.js中使用Axios
Axios为vue2.0官方推荐HTTP请求工具,之前的是vue-resource 在使用的过程中总结了两种使用方式: 1.和vue-resource使用类似 引入:import axios from ...
- 在使用Vue.js中使用axios库时,遇到415错误(不支持的媒体类型(Unsupported media type))
知识点:vue2.0中使用axios进行(put,post请求时),遇到415错误 解决办法:在axios的第三个参数config中,设置请求头信息'Content-Type': 'applicati ...
- vue.js提交按钮时简单的if判断表达式示例
简单的业务需求如下,看图说话 1:当充值金额没有填写的时候,会有Toast小弹框提示"请输入有效的充值金额" if (!this.money) { console.log('mon ...
- Vue.js(20)之 封装字母表(是这个名字吗0.0)
HTML结构: <template> <div class="alphabet-container"> <h1>alphabet 组件</ ...
- Vue.js(19)之 封装calendar组件
效果 需求 1.实现一个日历组件,如图: 2.显示某天的事项: 3.事项是模拟父组件请求接口返回的,数据格式如下: [ { id: '232', date: '2019-06-01', info: ' ...
随机推荐
- sass计算高度
页面布局时,有时候需要两个div充满父div空间,设定一个div尺寸后,可以使用css计算高度设置另一个尺寸: <style> .wrap{ width:1000px; } .left{ ...
- Mysql使用存储过程创建测试数据
一.概述 存储过程(Stored Procedure)是在大型数据库系统中,一组为了完成特定功能的SQL 语句集.其存储在数据库中,经过第一次编译后调用不需要再次编译,用户通过指定存储过程的名字并给出 ...
- C# 创建INI文件,写入并可读取。----转载
基于C#winform设计. 首先创建一个类,我命名为IniFiles.并引入命名空间using System.Runtime.InteropServices; 接着,声明API函数 [DllImpo ...
- Linux ---- 查看当前TCP连接数
一.查看哪些IP连接本机 netstat -an 二.查看TCP连接数 1)统计80端口连接数netstat -nat|grep -i "80"|wc -l 2)统计httpd协议 ...
- 使用Ubuntu系统编译安装Zabbix企业级监控系统
使用Ubuntu系统编译安装Zabbix企业级监控系统 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. Ubuntu系统部署笔记:https://www.cnblogs.com/ ...
- python isdigit()函数
isdigit() 函数是作用于字符串的,用来判断字符串是否全部由数字组成. x = '123456' y = 'iloveyou123' print(x.isdigit(),y.isdigit()) ...
- vue的MVVM
Vue的相关知识有 字符串模板 MVVM 虚拟dom和domdiff,查看下一篇笔记 字符串模板 function render(template, data) { const reg = /\{\{ ...
- docker安装并设置开机启动(Linux)
docker 开机启动: systemctl enable docker 使用的linux系统为CentOS7.2 docker分为CE和EE版本,EE版本收费,一般我们使用CE版本就满足要求了 do ...
- 洛谷P1002——过河卒
又是洛谷题,要不是有小姐姐不会,我才不想动脑子.先贴一下题目地址https://www.luogu.org/problem/P1002 再贴一下题目: 我们读一下题目,这可不比学校的**算法题,读完一 ...
- POJ 1256:Anagram
Anagram Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 18393 Accepted: 7484 Description ...