Vue---- Vue 3.x 中全局配置axios

简介: Vue---- Vue 3.x 中全局配置axios

vue 3.x 中全局配置 axios

0 安装 axios

npm i axios

1. 为什么要全局配置 axios

在实际项目开发中,几乎每个组件中都会用到 axios 发起数据请求。

此时会遇到如下两个问题:

① 每个组件中都需要导入 axios(代码臃肿)

② 每次发请求都需要填写完整的请求路径(不利于后期的维护)

2. 如何全局配置 axios

在 main.js 入口文件中,通过 app.config.globalProperties全局挂载 axios。

import { createApp } from 'vue'
// import App from './App.vue'
// import App from './components/myEvent/App.vue'
// import App from './components/v-model/App.vue'
// import App from './components/watch/App.vue'
// import App from './components/live/App.vue'
// import App from './components/fatherSon/App.vue'
// import App from './components/brother/App.vue'
import App from './components/grand/App.vue'
// 导入axios
import axios from 'axios'
import './index.css'
// 创建 Vue 实例对象
const app = createApp(App)
// 设置 axios 的请求根路径
axios.defaults.baseURL = 'https://www.escook.cn'
// 将 axios 挂载为 app 的全局自定义属性
// 每个组件可以通过 this 直接访问到全局挂载的自定义属性
app.config.globalProperties.$http = axios
app.mount('#app')

3. 发起get请求

<template>
  <div>
    <h1>App 组件</h1>
    <hr>
    <button @click="get">发起get请求</button>
  </div>
</template>
<script>
export default {
  name: 'App',
  methods: {
    async get() {
      // axios 返回的为 Promise 对象
      // 对返回的对象进行解构,获取其中的 data
      // 第一个参数为请求的路径,第二次参数为请求携带的数据
      const { data: res } = await this.$http.get( '/api/get', {
        params: {
          name: 'zs',
          age: 33
        }
      } )
      console.log( res )
    }
  }
}
</script>
<style>
</style

4. 发起post请求

<template>
  <div>
    <h1>App 组件</h1>
    <hr>
    <button @click="get">发起get请求</button>
    <button @click="post">发起post请求</button>
  </div>
</template>
<script>
export default {
  name: 'App',
  methods: {
    async get() {
      // axios 返回的为 Promise 对象
      // 对返回的对象进行解构,获取其中的 data
      // 第一个参数为请求的路径,第二次参数为请求携带的数据
      const { data: res } = await this.$http.get( '/api/get', {
        params: {
          name: 'zs',
          age: 33
        }
      } )
      console.log( res )
    },
    async post() {
      // 第一个参数为请求地址
      // 第二个参数为请求携带的数据
      const { data: res } = await this.$http.post( '/api/post', {
        name: 'zs',
        gender: '男'
      } )
      console.log(res)
    }
  }
}
</script>
<style>
</style>


相关文章
|
9天前
|
存储 JavaScript 开发者
Vue 3 组件通信方式总结
Vue 3 组件通信方式总结
|
6天前
|
缓存 监控 UED
升级 Vue3 时,如何减少打包体积的增加?
升级 Vue3 时,如何减少打包体积的增加?
86 59
|
6天前
|
JavaScript
在vue3中(vite)引入unocss,安装配置unocss
在vue3中(vite)引入unocss,安装配置unocss
|
6天前
|
API UED
升级 Vue3 后,项目的打包体积会有什么变化?
升级 Vue3 后,项目的打包体积会有什么变化?
93 57
|
7天前
|
缓存 JavaScript 前端开发
「offer来了」从基础到进阶原理,从vue2到vue3,48个知识点保姆级带你巩固vuejs知识体系
该文章全面覆盖了Vue.js从基础知识到进阶原理的48个核心知识点,包括Vue CLI项目结构、组件生命周期、响应式原理、Composition API的使用等内容,并针对Vue 2与Vue 3的不同特性进行了详细对比与讲解。
「offer来了」从基础到进阶原理,从vue2到vue3,48个知识点保姆级带你巩固vuejs知识体系
|
9天前
|
JavaScript
vue项目中使用vue-router进行路由配置及嵌套多级路由
该文章详细说明了如何在Vue项目中配置和使用vue-router进行单页面应用的路由管理,包括设置嵌套路由和实现多级路由导航的示例。
vue项目中使用vue-router进行路由配置及嵌套多级路由
|
6天前
|
API UED
如何实现Vue2项目升级Vue3?
如何实现Vue2项目升级Vue3?
14 1
|
9天前
|
JavaScript
在 Vue 3 组件通信方式中,Provide / Inject 与 Vuex 的区别是什么?
在 Vue 3 组件通信方式中,Provide / Inject 与 Vuex 的区别是什么?
|
9天前
|
存储 JavaScript
Vue 3 组件通信方式
Vue 3 组件通信方式
|
8天前
|
JavaScript 前端开发 API
vue3的传送门teleport究竟有多神奇?suspense发起异步请求有多简约?
该文章介绍了Vue3中新特性Teleport和Suspense的使用方法,演示了如何使用Teleport进行DOM节点的非父子关系传送,以及Suspense在处理异步组件加载时的优雅展示和错误处理技巧。