vue封装请求数据的接口

1.配置URL

(1)创建一个js文件

(2)区别测试环境和生产环境(正式环境)

let host;
if (process.env.NODE_ENV == 'development') {
   host = "xx.xx.xx.xx";
}else if (process.env.NODE_ENV == 'production') {
   host = "xx.xx.xx.xx"; //线上接口(生产环境包)
}

export const BASEURL = `http://${host}:端口号`;

2.封装接口

(1)创建network文件夹及base.js文件, network文件夹里全部放接口文件 ,在每个接口文件中引用base.js文件

(2)在base.js中封装

import axios from 'axios'
import { BASEURL } from '@/contant.js'

const instance1 = axios.create({
    baseURL: BASEURL
})

export default function request(config) {
    instance1.interceptors.request.use(config => {
        let token = window.localStorage.getItem("authToken");
        token && (config.headers.Authorization = token);
        return config
    },error => {
        return Promise.error(error);
      }
    )
    instance1.interceptors.response.use(result => {
        if (result.status === 200) {
          if (result.data.code == -1004) {   //登录过期
            window.location.replace('/');
            localStorage.removeItem('authToken')
          }else if(result.data.code == -1005) {  //用户未登录
            window.location.replace('/')
            localStorage.removeItem('authToken')
          }else if(result.data.code == -1006){   //当前用户无权限
            // return Promise.resolve(result.data.message);
          }
          return Promise.resolve(result);
        }else {
          return Promise.reject(result);
        }
    })
    return instance1(config)
}

 (3)新建一个接口文件position.js , 现在每个接口文件中可直接引用base.js中的request

import request from '@/network/base.js'

function list() {
    return request({
        method: "GET",
        url: "/api/list"
    })
}

function changePosition(config) {
    return request({
        method: "POST",
        url: "api/changePosition",
        data: config
    })
}

export default {
    list: list,
    changePosition:changePosition
}

3.在vue文件中使用

(1)引用

 (2)使用

loadData() {
      position.list().then((res)=>{
        if (res.data.code === 200) {
          this.tableData = res.data.data;
        }else{
          this.$message.warning(res.data.message);
        }
      }).catch((err=>{
        console.log(err)
      }))
    },

如有问题,欢迎留言!!!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值