vue中如何实现局部刷新效果

本文介绍了在Vue项目中如何利用axios的请求拦截器和响应拦截器来实现局部刷新效果。首先创建http.js文件配置axios,设置startLoading和endLoading函数以控制加载状态。然后在main.js中引入http.js并将其绑定到Vue实例上。
摘要由CSDN通过智能技术生成

请求拦截器和响应拦截器

1.新增一个http.js文件,配置axios响应拦截器和请求拦截器。然后再导入Loading组件。并设置startLoading和endLoading两个函数,作用就是如函数名所示了。

 

import axios from 'axios'
import { Message, Loading } from 'element-ui'

let loading

function startLoading() {
    loading = Loading.service({
        lock: true,
        text: '为小主拼命加载中...',
        background: 'rgba(0,0,0,7)'
    })
}

function endLoading() {
    loading.close()
}

// 请求拦截
axios.interceptors.request.use(config => {
    startLoading()
    return config
}, error => {
    return Promise.reject(error)
})

// 响应拦截
axios.interceptors.response.use( response => {
    endLoading()
    return response
}, error => {
    endLoading()
    Message.error(error.response.data)
    return Promise.reject(error)
})


export default axios

 

main.js中引入http.js并绑定在vue上

impo
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值