怎么在vue项目中利用axios请求对网络接口进行封装
怎么在vue项目中利用axios请求对网络接口进行封装?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

创新互联建站是一家集网站建设,潜山企业网站建设,潜山品牌网站建设,网站定制,潜山网站建设报价,网络营销,网络优化,潜山网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
(1).新建一个js文件,取名api.js
(2).引入 axios ,mint-UI ,如下图:
import axios from 'axios'
import {MessageBox, Toast} from 'mint-ui'
axios.defaults.timeout = 50000//默认请求超时时间
axios.defaults.headers = '请求头'(2).封装get方法
export function getHttp (url, params = {}) {
// 创建动画mint-ui
Indicator.open({
text: '加载中...',
spinnerType: 'fading-circle'
})
return new Promise((resolve, reject) => {
axios.get(url, {
params: params
})
.then(response => {
resolve(response.data)
Indicator.close() // // 关闭动画
})
.catch(err => {
reject(err)
Indicator.close() // // 关闭动画
MessageBox.alert('message', err)
})
})
}(4).封装post方法
export function postHttp (url, data = {}) {
Indicator.open({
text: '加载中...',
spinnerType: 'fading-circle'
})
return new Promise((resolve, reject) => {
axios.post(url, data)
.then(response => {
if (response.data.status == 1) {
resolve(response.data)
} else {
Toast(response.data.msg)
}
Indicator.close() // // 关闭动画
}, (err) => {
reject(err)
Indicator.close()
})
})
}(5).封装后方法的使用
在main.js中引入全局变量
import {getHttp, postHttp} from './config/api'
Vue.prototype.$getHttp = getHttp
Vue.prototype.$postHttp = postHttp
//get网络请求
this.$getHttp(this.$shopUrl + 'api/product/list',)
.then((response) => {
response.result//请求返回数据
})
// post网络请求
this.$postHttp(this.$shopUrl + 'api/product/list',)
.then((response) => {
response.result//请求返回数据
})关于怎么在vue项目中利用axios请求对网络接口进行封装问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。
当前名称:怎么在vue项目中利用axios请求对网络接口进行封装
文章位置:http://www.scyingshan.cn/article/jjshdj.html


咨询
建站咨询
