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: ' ...
随机推荐
- 吴裕雄--天生自然JAVA数据库编程:处理大数据对象
import java.sql.Connection ; import java.sql.DriverManager ; import java.sql.SQLException ; import j ...
- CentOS LVM 卷在线扩容
场景: vmware 虚拟机,装了CentOS ,更改了虚拟机磁盘的大小:从200G,扩展到320G,可以参考本文写了步骤. 1. 在线扫描虚拟机SCSI新增的容量 # for i in `find ...
- js - 获取当前年月日
var date = new Date(); date .getYear(); //获取当前年份(2位) date .getFullYear(); //获取完整的年份(4位) date .getMon ...
- JSONPath 表达式的使用
一.JSONPath使用需要的包 <dependency> <groupId>com.jayway.jsonpath</groupId> <artifactI ...
- 013-PHP输出表格
<?php // 数据表格化 print("<TABLE bgcolor='ffccoo' BORDER=\"1\">\n"); // 表格开 ...
- 图片与byte相互转换
一.图片转byte public byte[] ImageToByte() { string imagefile = @"http://192.168.0.212/pass/T-1.jpg& ...
- javascript判断数组是否包含了指定的元素
jQuery写法: var arr = [ "xml", "html", "css", "js" ]; $.inArra ...
- 移动 web 开发问题和优化小结
1.前言 到目前为止,互联网行业里,手机越来越智能化,移动端占有的比例越来越高,尤其实在电商,新闻,广告,游戏领域.用户要求越来越高,网站功能越来越好,效果越来越炫酷,这就要求我们产品质量越来越高,w ...
- Most simple basic of internet programming based on two different machines sharing the same local net
This blog is just shown for the most simple basic of internet programming based on two different mac ...
- MyBatis: No MyBatis mapper was found in '[xx.mapper]' package. Please check your configuration
在应用入口加入@MapperScan("com.IBM.XXXXX.dao")