vue全家桶进阶之路46:Vue3 Axios拦截器和globalProperties全局设置

这篇具有很好参考价值的文章主要介绍了vue全家桶进阶之路46:Vue3 Axios拦截器和globalProperties全局设置。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在Vue.js 3中,使用Axios与Vue.js 2.x中类似,但是需要进行一些修改和更新,下面是Vue.js 3中Axios的定义和使用方式:

首先,你需要安装Axios和Vue.js 3.x,可以使用npm或yarn等包管理工具安装:

npm install axios vue@next

然后,在你的Vue.js 3应用程序中,你可以使用以下代码来导入和使用Axios:

import { ref } from 'vue'
import axios from 'axios'

export default {
  setup() {
    const data = ref(null)
    const error = ref(null)

    axios.get('/api/data')
      .then(response => {
        data.value = response.data
      })
      .catch(error => {
        error.value = error
      })

    return { data, error }
  }
}

上面的代码使用Axios发出一个GET请求,从API端点/api/data获取数据,并将响应数据赋值给Vue组件的data变量中,如果请求出错,则将错误信息赋值给error变量。

注意,在Vue.js 3中,使用Axios时,需要将其包装在Vue 3的Reactivity API中,例如,上面的代码中,使用了Vue 3的ref函数将dataerror变量转换为响应式对象。

除此之外,在Vue.js 3中,你可以将Axios作为插件使用,并在Vue实例中进行全局配置。下面是一个示例:

import { createApp } from 'vue'
import axios from 'axios'
import App from './App.vue'

const app = createApp(App)

app.config.globalProperties.$axios = axios
// 在这里添加更多的全局配置

app.mount('#app')

上面的代码将Axios作为Vue的插件,并将其添加到Vue实例的全局属性$axios中,以便在应用程序的任何组件中使用。

总之,Vue.js 3中的Axios使用与Vue.js 2.x基本相同,但需要使用Vue 3的Reactivity API将数据转换为响应式对象。此外,你可以将Axios作为Vue的插件使用,并在Vue实例中进行全局配置。

globalProperties 

globalProperties 是 Vue 3 中的一个全局配置对象,它允许你在应用程序的任何地方添加自定义的全局属性和方法。

在 Vue.js 3 中,你可以使用 app.config.globalProperties 对象添加全局属性和方法,这样在 Vue 实例中就可以直接访问它们,而不需要在每个组件中都进行导入。

例如,你可以通过以下方式在 globalProperties 中添加一个全局属性 $myGlobalData

const app = createApp(App)

app.config.globalProperties.$myGlobalData = { name: 'John', age: 30 }

app.mount('#app')

这样,在 Vue 组件中就可以通过 $myGlobalData 访问这个全局属性:

export default {
  setup() {
    const data = ref($myGlobalData)
    return { data }
  }
}

同样,你也可以在 globalProperties 中添加全局方法:

const app = createApp(App)

app.config.globalProperties.$myGlobalMethod = function() {
  console.log('This is a global method!')
}

app.mount('#app')

然后,在 Vue 组件中就可以通过 $myGlobalMethod() 调用这个全局方法:

export default {
  setup() {
    $myGlobalMethod() // 输出:This is a global method!
  }
}

需要注意的是,globalProperties 中添加的全局属性和方法会在所有 Vue 组件中共享,并且会被所有组件实例继承。因此,你需要确保添加的全局属性和方法不会与组件实例中的属性和方法冲突。

ctx 

在 Vue 3 中,ctx 是组件上下文对象,它包含了一个组件实例的所有属性和方法。

在 Vue 3 的组件中,你可以使用 setup() 函数来编写组件的逻辑代码。setup() 函数会接收一个 ctx 参数,它是一个组件上下文对象,包含了许多属性和方法,可以帮助你访问和操作组件实例。

下面是 ctx 对象中的一些常用属性和方法:

  • attrs: 包含了所有传递给组件的非响应式属性,例如 idclassstyle 等。

  • emit: 用于触发自定义事件,可以传递任意数量的参数。例如,ctx.emit('my-event', arg1, arg2) 将触发名为 my-event 的自定义事件,并传递 arg1arg2 两个参数。

  • expose: 用于暴露组件的属性和方法,使它们可以被父组件访问。例如,ctx.expose({ myProp, myMethod })myProp 属性和 myMethod 方法暴露给父组件。

  • slots: 包含了所有插槽内容的函数或者节点,可以使用 v-slot 或者 slot-scope 来定义插槽。

  • attrs: 包含了所有传递给组件的非响应式属性,例如 idclassstyle 等。

  • listeners: 包含了所有绑定在组件上的事件监听器,可以通过 v-on 或者 @ 绑定事件。例如,<my-component @click="handleClick" /> 将在 ctx.listeners 中包含一个名为 click 的属性,它的值是 handleClick 方法。

  • root: 当前组件树中的根组件实例。

  • refs: 包含了所有在组件上使用 ref 注册的 DOM 元素或组件实例,可以使用 ctx.refs.refName 访问。

  • attrs: 包含了所有传递给组件的非响应式属性,例如 idclassstyle 等。

需要注意的是,ctx 对象中的属性和方法都是只读的,你不能修改它们的值。如果你需要修改组件实例的属性或者方法,你可以在 setup() 函数中使用 refreactivecomputed 等响应式 API 来创建可响应的变量和方法。

Proxy 

Proxy 是 ES6 中新增的一种原生对象,用于在运行时动态地拦截和处理 JavaScript 对象的操作。它提供了一个可编程的代理,可以对目标对象进行操作前进行预处理和过滤,从而可以用来实现许多高级功能,例如数据绑定、数据校验、属性拦截等。

Proxy 对象的基本用法如下:

let target = { name: 'John', age: 30 };
let proxy = new Proxy(target, {
  get: function(target, prop, receiver) {
    console.log(`Getting ${prop} from target`);
    return target[prop];
  },
  set: function(target, prop, value, receiver) {
    console.log(`Setting ${prop} to ${value} on target`);
    target[prop] = value;
    return true;
  }
});

proxy.name; // Output: "Getting name from target", "John"
proxy.age; // Output: "Getting age from target", 30
proxy.location = "New York"; // Output: "Setting location to New York on target"

在上面的例子中,我们创建了一个名为 target 的普通对象,然后用 Proxy 对象对其进行包装。在 Proxy 对象的第二个参数中,我们定义了一个拦截器对象,包含了两个方法 getset。当我们对 proxy 对象进行属性读取时,会触发 get 方法,输出一个日志和目标对象中对应属性的值;当我们对 proxy 对象进行属性设置时,会触发 set 方法,输出一个日志,并将目标对象中对应属性的值进行更新。

除了上面的 getset 方法之外,Proxy 还提供了许多其他的拦截方法,包括 applyconstructdefinePropertydeletePropertygetOwnPropertyDescriptorgetPrototypeOfhasisExtensibleownKeyspreventExtensionssetPrototypeOf 等。你可以在这些拦截方法中进行各种预处理和过滤操作,从而实现各种高级功能。

需要注意的是,Proxy 对象只能对对象进行操作,不能对原始值进行操作。此外,由于 Proxy 对象会对目标对象进行包装,所以会导致一定的性能损耗,因此应该谨慎使用。

 

getCurrentInstance 

ctxgetCurrentInstance 都是 Vue 3 中的全局 API,用于在组件中获取当前上下文和当前组件实例对象,但它们的作用不完全相同。

ctx 是一个包含了组件实例对象以及一些额外属性和方法的上下文对象,它可以在组件的模板和组合式 API 中使用。ctx 包含了许多属性和方法,例如 attrsemitslotsroot 等,这些属性和方法可以让我们更方便地访问组件的数据和方法。例如,我们可以通过 ctx.attrs 来访问组件的属性,通过 ctx.emit 来触发组件的自定义事件。

getCurrentInstance 则是一个用于获取当前组件实例对象的全局 API,它可以在组件的模板和组合式 API 中使用。与 ctx 不同的是,getCurrentInstance 返回的是当前组件实例对象本身,而不是一个包含了组件实例对象的上下文对象。这意味着,通过 getCurrentInstance 我们可以访问到组件实例对象的所有属性和方法,而不仅仅是 ctx 中包含的属性和方法。例如,我们可以通过 getCurrentInstance().$refs 来访问组件的引用。

需要注意的是,ctxgetCurrentInstance 都是 Vue 3 中的 API,在 Vue 2 中并不存在。在 Vue 2 中,我们可以通过 this 来访问组件实例对象和组件的数据和方法。文章来源地址https://www.toymoban.com/news/detail-419634.html

到了这里,关于vue全家桶进阶之路46:Vue3 Axios拦截器和globalProperties全局设置的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue全家桶进阶之路37:Vue3 状态管理

    Vue3 的状态管理主要是通过 Vuex 4 来实现。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 在Vue3的状态管理中,以下是各个属性的作用: state :存储应用程序中的状

    2023年04月18日
    浏览(41)
  • vue全家桶进阶之路39:Vue3 状态管理

    Vue3 的状态管理主要是通过 Vuex 4 来实现。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 在Vue3的状态管理中,以下是各个属性的作用: state :存储应用程序中的状

    2023年04月18日
    浏览(42)
  • vue全家桶进阶之路33:Vue3 计算属性computed

    在Vue3中,计算属性可以使用 computed 函数来定义。 computed 函数接受两个参数:第一个参数是一个函数,该函数返回计算属性的值;第二个参数是一个可选的配置对象,可以包含getter和setter函数,以及控制计算属性缓存的缓存配置。 Vue3中的计算属性与Vue2中的计算属性相比有以

    2023年04月18日
    浏览(47)
  • vue全家桶进阶之路34:Vue3 路由基本配置

    在Vue3中,路由的基本配置是通过使用Vue Router库来实现的。以下是Vue3中路由的基本配置步骤: 安装Vue Router 使用npm或yarn在项目中安装Vue Router: 创建路由实例 创建一个路由实例并定义路由规则。路由规则是一个对象数组,其中每个对象都定义了一个路由的路径和组件。 例如

    2023年04月18日
    浏览(48)
  • vue全家桶进阶之路50:Vue3 环境变量+跨域设置实例

    使用.env加后缀的方式来建立某个模式下的环境变量, 例如:项目根目录新建两个环境变量文件(development开发环境和production生产环境):  在新建的两个环境变量文件中设置相同的环境变量名: 环境变量名称必须以\\\"VUE_API_\\\"+名称的格式,否则不生效,这个格式是死的。至于

    2023年04月21日
    浏览(45)
  • vue全家桶进阶之路32:Vue3 WatchEffect和watch 监听

    在 Vue 3 中, watchEffect 是一个用于监听响应式数据变化的 API。它可以在函数内部自动跟踪数据的依赖,并在依赖变化时重新运行函数。 watchEffect  的作用以及各个参数的功能讲解: watchEffect(effect: (onInvalidate: InvalidateCbRegistrator) = void | (() = void) | Promisevoid, options?: WatchEffectOptio

    2023年04月17日
    浏览(78)
  • vue全家桶进阶之路48:Vue3 跨域配置devServer的参数和设置

    devServer 是一个用于配置开发服务器的选项对象。它可以用来配置服务器的各种选项,例如代理,端口号,HTTPS 等。 以下是一些常用的 devServer 参数和设置: port :指定开发服务器的端口号,默认为 8080 。 host :指定开发服务器的主机名,默认为 localhost 。 https :开启 HTTPS,可

    2023年04月21日
    浏览(45)
  • vue全家桶进阶之路43:Vue3 Element Plus el-form表单组件

    在 Element Plus 中, el-form 是一个表单组件,用于创建表单以便用户填写和提交数据。它提供了许多内置的验证规则和验证方法,使表单验证更加容易。 使用 el-form 组件,您可以将表单控件组织在一起,并对表单进行验证,以确保提交的数据符合预期的格式和要求。该组件具有

    2023年04月20日
    浏览(45)
  • vue全家桶进阶之路31:Vue3 数据和方法的双向绑定ref、reactive、toRefs

    ref 在 Vue 3 中,你可以使用 setup 函数来定义组件的数据和方法。在 setup 函数中,你可以使用 ref 、 reactive 和 computed 等 Vue 3 的响应式 API 来定义数据,并返回一个包含你需要公开的数据和方法的对象。下面是一个例子: 在这个例子中,我们使用 ref 函数来定义了一个名为 mes

    2023年04月19日
    浏览(54)
  • Vue axios 拦截器

    正常情况下打开浏览器前端页面向后端发起请求使用的是axios,无论是原生的axios还是自己封装的axios都看成是axios。发起请求之后后端去数据库里面拿数据,然后返回给前端。 发起请求的地方是axios,并且你能够封装这个axios,那么你就可以添加拦截器。 请求拦截器就是你在

    2024年02月04日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包