VUE axios 后台请求地址可动态修改

1、方便多端打包,baseURL引用全局变量

◇ static下新建config.js文件,设置一个BASE_API

var BASE_API='/default'
复制代码

◇ 根目录下找到.eslintrc.js文件 修改配置

 

 

修改完毕则可以全局使用这个变量(防止编辑器报错提醒)

 

◇ 在index.html引入这个静态js文件,为方便打包可以再写一个打包后的路径

2、封装的axios文件修改

脚手架搭建的一般为baseURL: process.env.BASE_API

// 创建axios实例
var service = axios.create({
  baseURL: process.env.BASE_API, // api的base_url
  timeout: 1200000, // 请求超时时间
  transformRequest: [
    function (data) {
      // Do whatever you want to transform the data
      let ret = ''
      for (const it in data) {
        ret +=
          encodeURIComponent(it) +
          '=' +
          encodeURIComponent(data[it]) +
          '&'
      }
      return ret
    }
  ],
  headers: {
    'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'
  }
})
复制代码

开始将baseURL直接修改为baseURL: BASE_API

但发现页面修改这个值 请求依旧不变

正确的修改是在use时修改 于是将baseURL先设置空字符串 baseURL: ''

在return config前再对url重新设置下

// request拦截器
service.interceptors.request.use(config => {
  if (window.localStorage.getItem('tooken')) {
    config.headers['x-auth-token'] = window.localStorage.getItem('tooken') // 让每个请求携带自定义token 请根据实际情况自行修改
  }
  config.url = BASE_API + config.url
  return config
}, error => {
  // Do something with request error
  // router.push({
  //   path: '/login'
  // })
  console.log(error, '请求错误') // for debug
  Promise.reject(error)
})
复制代码

文章

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
前置知识: - Vue3.0 - Axios - 微服务 Axios是一个基于Promise的HTTP库,可以用于浏览器和Node.js。在Vue中,我们通常使用Axios来发送HTTP请求。 微服务是一种面向服务架构的软件设计风格。它把一个应用划分为一些小的、独立的、可替换的服务,每个服务运行在自己的进程中,服务之间通过轻量级通信机制互相协作。微服务架构可以提高应用的可伸缩性和可维护性。 下面是一个基于Vue3和Axios的微服务请求封装示例: 1. 安装Axios ``` npm install axios ``` 2. 创建axios实例 ```js import axios from 'axios' const service = axios.create({ baseURL: process.env.VUE_APP_BASE_API, // 微服务请求的基础路径 timeout: 5000 // 超时时间 }) // 请求拦截器 service.interceptors.request.use( config => { // 在请求发送之前做些什么 return config }, error => { // 对请求错误做些什么 console.log(error) // for debug return Promise.reject(error) } ) // 响应拦截器 service.interceptors.response.use( response => { // 对响应数据做些什么 const res = response.data if (res.code !== 20000) { // 如果响应状态码不是20000,则视为错误 return Promise.reject(new Error(res.message || 'Error')) } else { return res } }, error => { // 对响应错误做些什么 console.log('err' + error) // for debug return Promise.reject(error) } ) export default service ``` 3. 封装请求方法 ```js import request from '@/utils/request' export function getUserInfo() { return request({ url: '/user/info', method: 'get' }) } export function login(data) { return request({ url: '/user/login', method: 'post', data }) } export function logout() { return request({ url: '/user/logout', method: 'post' }) } ``` 在组件中使用: ```js import { getUserInfo } from '@/api/user' export default { name: 'HelloWorld', created() { getUserInfo().then(response => { console.log(response) }) } } ``` 这样就完成了基于Vue3和Axios的微服务请求封装。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值