Vue3应用API——use解析

本文介绍了Vue中app.use的功能及其使用场景,并详细讲解了如何封装自定义插件,包括两种不同的写法、如何应用插件以及注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


一、app.use

1.使用场景

  不论是Vue2中的Vue.use亦或者Vue3中的app.use。其功能主要是用在插件的安装上,往往是在项目的入口文件(比如main.js)中。被use的插件多数是 NPM 中的第三方库 。在必要的时候,也可以封装一个自定义的插件以供团队的使用。这样可以避免反复开发同一个功能。

2.原理

  从Vue源码对 app.use 描述可以看出,app.use(plugin) 中的核心部分“plugin(app, …options)”“plugin.install(app, …options)” 这两句;
  也就是说,app.use(plugin),本质上就是把plugin中的 install 方法调用一遍
  不仅如此,还可以发现 Vue 框架在 install 函数中暴露了 app实例, 所以在实际开发中能挂载到 app实例上的都可以在install函数中实现,然后通过app.use()将插件快速地应用到各个项目中;
  由此看来,我们也可以通过封装自定义插件供开发使用。

二、封装自定义插件

  一个插件可以是一个拥有 install() 方法的对象,也可以直接是一个安装函数本身

1.写法一

拥有 install() 方法的对象

// 写法一:对象中定义 install 函数
let myPlugin = {
    install(app) {
        // 定义一个实例方法
        app.config.globalProperties.sayHello = function () {
            alert('Hello, Nancy!');
        }
        // 定义一个全局指令:元素挂载后"自动聚焦"及"动态绑定数据"
        app.directive('myModel', {
            mounted(el, binding) {
                el.focus();
                el.value = binding.value;
            },
        })
        // 定义一个全局按钮组件
        app.component('el-button', {
            name: "el-button",
            template: '<button value="按钮">ElementUI按钮</button>'
        })
    }
}
export default myPlugin;

2.写法二

直接是一个安装函数本身

// 写法二:直接定义 install 函数
let install = function (app, options) {
    // 定义一个实例方法
    app.config.globalProperties.sayHello = function () {
        alert('Hello, Nancy!');
    }
    // 定义一个全局指令:元素挂载后"自动聚焦"及"动态绑定数据"
    app.directive('myModel', {
        mounted(el, binding, vnode, prevNode) {
            el.focus();
            el.value = binding.value;
        },
    })
    // 定义一个全局按钮组件
    app.component('el-button', {
        name: "el-button",
        template: '<button value="按钮">ElementUI按钮</button>'
    })
}
export default install;

3.应用插件

应用自定义插件(main.js)

import myPlugin from './plugin/myPlugin';
// 自动调用插件 myPlugin 的 install 方法
app.use(myPlugin);

组件中测试

<template>
  <!-- 测试插件中定义的全局按钮组件和实例方法 -->
  <el-button @click="sayHello()"></el-button>
  <!-- 测试自定义指令 -->
  <input type="text" v-myModel="msg">
</template>

<script setup>
import { ref } from 'vue';
let msg = ref('测试v-myModel指令');
</script>

效果

4.注意事项

  注意:不要滥用插件,多个项目都需要使用时才抽离成一个Vue插件,然后封装成一个Npm包。


总结

  app.use 在 Vue 中的作用主要是帮助团队将一些在各个部门中都需要使用的公共的与业务无关的部分从现有业务中抽离出来,形成一个独立的和业务无关的第三方库,以便在下次项目中直接通过use使用。NPM上就有大量的第三方库或者组件等,例如moment、element-ui等都属于与业务无关但是又经常使用的公共部分,便可以采用这种方法引入。

### Vue3 环境中 Token 的处理方法 #### 使用 Vuex 进行状态管理 为了更好地管理和共享应用的状态,在 Vue3 中可以利用 Vuex 来存储和操作全局的 token 数据。通过调用 `Vue.use()` 方法安装 Vuex 插件之后,便能够在各个组件内借助 `this.$store` 访问到集中式的 store 实例及其内部定义的状态属性,比如这里的 token 值[^1]。 ```javascript // main.js 初始化Vuex并挂载至Vue实例上 import { createApp } from &#39;vue&#39;; import App from &#39;./App.vue&#39;; import store from &#39;./store&#39;; createApp(App).use(store).mount(&#39;#app&#39;); ``` #### 存储与读取 Token 当用户成功登录后获得的有效凭证(即 token),应当被妥善存放在浏览器本地持久化机制 LocalStorage 或者 SessionStorage 当中以便于后续重复使用。每当发起新的 HTTP 请求时,则需先从上述位置取出该令牌附加到请求头里作为身份验证依据[^2]。 ```javascript // 登录接口返回token后的保存逻辑 localStorage.setItem(&#39;token&#39;, response.data.token); // 组件内的fetchData函数用于携带token发送受保护资源请求 methods: { fetchData() { const token = localStorage.getItem(&#39;token&#39;); axios.get(&#39;/api/protected-data&#39;, { headers: { Authorization: `Bearer ${token}` } }) .then(/* ... */) .catch(/* ... */); } } ``` #### 刷新页面保持会话有效性的策略 考虑到单页应用程序的特点以及用户体验连续性方面的要求,建议采取措施确保即使刷新网页也能维持当前用户的登录状态不变。具体做法是在每次启动应用之初就尝试自动恢复之前存在的 session 信息——如果检测到了有效的 token 字符串存在的话就可以认为用户仍然处于已授权状态下而无需重新输入账号密码再次登陆[^3]。 ```javascript // 在main.js入口处提前加载token进入vuex state const savedToken = window.localStorage.getItem(&#39;token&#39;) || null; if (savedToken !== null && savedToken.length > 0) { store.commit(&#39;SET_TOKEN&#39;, savedToken); // 自定义mutation更新state里的token字段 } // 对应mutation定义如下所示 mutations: { SET_TOKEN(state, token){ state.token = token; }, }, ``` #### 后端支持 JWT 验证方式集成指南 对于采用 Spring Boot 构建的服务端而言,可以通过引入第三方库来简化 JSON Web Tokens(JWTs) 的解析过程。例如添加 Maven 依赖项 `<dependency><groupId>com.auth0</groupId><artifactId>java-jwt</artifactId></dependency>` 即可快速启用这一功能特性[^4]。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JV_32

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值