Vue应用API——use解析
admin
2024-04-04 22:15:56

文章目录

  • 一、app.use
    • 1.使用场景
    • 2.原理
  • 二、封装自定义插件
    • 1.写法一
    • 2.写法二
    • 3.应用插件
    • 4.注意事项
  • 总结


一、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: ''})}
}
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: ''})
}
export default install;

3.应用插件

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

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

组件中测试


效果

4.注意事项

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


总结

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

相关内容

热门资讯

生活太苦?来块红枣南瓜发糕:软... 闹钟响了三次,我挣扎着从床上爬起来。窗外的天还是灰蒙蒙的,城市尚未完全苏醒,只有远处偶尔传来的几声鸟...
金玉其外的茶,抵不过记挂你的人 前天晚上,一个年轻的朋友微信联系我。她说有人送了她一盒黄山毛峰,我知道她,现在的年轻人根本不喝茶,他...
一抹相承聚势拓新,梵净抹茶香溢... 5月31日上午,以“一抹相承,聚势拓新;梵净抹茶,香溢天下”为主题的2026抹茶大会,在贵州省铜仁市...
【成冠美食】2025—2026... 2026.6.1—2026.6.7 本周食谱 新鲜食材 科学搭配 一日三餐对孩子们的健康成长 有着至...