Vue2使用axios,request.js和vue.config.js

Posted on 2022-03-16 09:54  晓晓晓渡  阅读(277)  评论(1编辑  收藏  举报

1.配置request.js,用来请求数据

import axios from 'axios'

// 1:利用axios对象的方法create,创建一个axios实例
// 2:request就是axios,但可以稍加配置
const request = axios.create({
    baseURL: '/api',  // 注意!! 这里是全局统一加上了 '/api' 前缀,也就是说所有接口都会加上'/api'前缀在,页面里面写接口的时候就不要加 '/api'了,否则会出现2个'/api',类似 '/api/api/user'这样的报错,切记!!!
    timeout: 5000
})

// request 拦截器,请求拦截器,在发请求之前,请求拦截器可以检测到
// 可以自请求发送前对请求做一些处理
// 比如统一加token,对请求参数统一加密
request.interceptors.request.use(config => {
    config.headers['Content-Type'] = 'application/json;charset=utf-8';
  
 // config.headers['token'] = user.token;  // 设置请求头
    return config
}, error => {
    return Promise.reject(error)
});

// response 拦截器, 响应拦截器
// 可以在接口响应后统一处理结果
request.interceptors.response.use(
    response => {
        let res = response.data;
        // 如果是返回的文件
        if (response.config.responseType === 'blob') {
            return res
        }
        // 兼容服务端返回的字符串数据
        if (typeof res === 'string') {
            res = res ? JSON.parse(res) : res
        }
        return res;
    },
    error => {
        console.log('err' + error) // for debug
        return Promise.reject(error)
    }
)

// 对外暴露
export default request
View Code

2.再main.js中注册

// 引入axios配置
import request from './api/request';
Vue.prototype.request = request
View Code

 3.接下来就可以在页面中发送请求,如

 // 新增or修改
    save() {
      this.request.post("/user/saveOrUpdate", this.form).then((res) => {
        if (res) {
          this.$message.success("保存成功");
          this.dialogFormVisible = false;
          this.load();
        } else {
          this.$message.error("保存失败");
          this.dialogFormVisible = false;
        }
      });
    }
View Code
 // 删除
    handleDelete(id) {
      this.request.delete("/user/delete" + id).then((res) => {
        if (res) {
          this.$message.success("删除成功");
          this.load();
        } else {
          this.$message.error("删除失败");
        }
      });
    }

  // 批量删除
    deleteBatch(){
      let ids =this.multipleSelection.map(v=>v.id)  //{[],[],[]}=>[1,2,3]
      this.request.post("/user/deleteBatch" , ids).then((res) => {
        if (res) {
          this.$message.success("批量删除成功");
          this.load();
        } else {
          this.$message.error("批量删除失败");
        }
      });
    }
View Code

 

Copyright © 2024 晓晓晓渡
Powered by .NET 8.0 on Kubernetes