浅谈Vue.use到底是什么?

浅谈Vue.use到底是什么?

Vue.use到底是什么鬼、下面本篇文章就来给大家介绍一下Vue.use。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

我们在使用Vue做项目开发的时候,看到不少轮子都是通过Vue.use来进行使用,感觉甚是高大上。

不过Vue.use到底是什么鬼?不妨来看个究竟。

其实这些轮子都可以称之为插件,它的功能范围没有严格的限制,一般包含如下几种:

立即学习“前端免费学习笔记(深入)”;

添加全局方法或者属性。如: vue-custom-element添加全局资源:指令/过滤器/过渡/组件等。如 vue-touch通过全局混入来添加一些组件选项。如 vue-router添加 Vue 实例方法,通过把它们添加到 Vue.prototype 上实现。一个库,提供自己的 API,同时提供上面提到的一个或多个功能。如 vue-router

无论大小,插件要实现的功能无非就是上述这几种。但是,这并不妨碍我们创造出复杂的插件,不过我们还是希望给用户提供一个简单的使用方法,他不需要关注插件内部做了些什么。固Vue提供了use方法,专门来在new Vue()之前使用插件。

不管是官方提供的插件(例如vue-router、vuex),还是第三方的插件(例如ElementUI、ant)都是采用了此方式,不外乎插件内部的功能不同而已。当然,还有其他诸多此类插件,awesome-vue 就集合了大量由社区贡献的插件和库。

接下来,我们就来看下这个神秘的use方法是如何实现的。

Vue.js 的插件应该暴露一个 install 方法。这个方法的第一个参数是 Vue 构造器,第二个参数是一个可选的选项对象,用于传入插件的配置:

MyPlugin.install = function (Vue, options) {  // 1. 添加全局方法或属性  Vue.myGlobalMethod = function () {    // 逻辑...  }  // 2. 添加全局资源  Vue.directive('my-directive', {    bind (el, binding, vnode, oldVnode) {      // 逻辑...    }    ...  })  // 3. 注入组件选项  Vue.mixin({    created: function () {      // 逻辑...    }    ...  })  // 4. 添加实例方法  Vue.prototype.$myMethod = function (methodOptions) {    // 逻辑...  }  // 5. 注册全局组件  Vue.component('myButton',{    // ...组件选项  })}

登录后复制

Vue.use(MyPlugin,{  // ...options})

登录后复制

一个插件内部大概就是如上所示,其实也不外乎上述那几种东西,甚是简单。接下来我们就来看下真实的案例ElementUI:

const components = [ Pagination, Dialog, Autocomplete/* 此处由于篇幅省略若干个组件 */];const install = function(Vue, opts = {}) {  locale.use(opts.locale);  locale.i18n(opts.i18n);  // 注册全局组件  components.forEach(component => {    Vue.component(component.name, component);  });  Vue.use(InfiniteScroll);  Vue.use(Loading.directive);  // 添加实例方法  Vue.prototype.$ELEMENT = {    size: opts.size || '',    zIndex: opts.zIndex || 2000  };  // 添加实例方法  Vue.prototype.$loading = Loading.service;  Vue.prototype.$msgbox = MessageBox;  Vue.prototype.$alert = MessageBox.alert;  Vue.prototype.$confirm = MessageBox.confirm;  Vue.prototype.$prompt = MessageBox.prompt;  Vue.prototype.$notify = Notification;  Vue.prototype.$message = Message;};/* istanbul ignore if */if (typeof window !== 'undefined' && window.Vue) {  install(window.Vue);}export default {  version: '2.13.0',  locale: locale.use,  i18n: locale.i18n,  install,  CollapseTransition,  Loading,  Pagination,  Dialog,  Autocomplete,  // ...other components};

登录后复制

我们不难发现,其实自己来实现一个插件也是超级简单,只要对外暴露一个install方法即可,在使用Vue.use的时候,会调用这个方法。所以我们只要将要实现的内容放到install内部即可。这样的好处就是插件需要一开始调用的方法都封装在install里面,更加精简和可拓展性更高。

大家可能也有注意到,这里的install其实是将所有的组件全部引入了。作为一个庞大的插件库,这样可能会有一些性能问题。用过的ElementUI的同学都知道,它是支持按需引入的,其实在上面的示例中也可以发现一些蛛丝马迹。

const components = [ Pagination, Dialog, Autocomplete/* 此处由于篇幅省略若干个组件 */];// ....省去中间内容export default {  version: '2.13.0',  locale: locale.use,  i18n: locale.i18n,  install,  CollapseTransition,  Loading,  Pagination,  Dialog,  Autocomplete,  // ...other components};

登录后复制

这里将每个组件都单独都导出了,而在每个组件内部,也类似的暴露了install来组件每个组件,这样就可以单独Vue.use每个组件,从而实现按需引入的目的。

import Alert from './src/main';/* istanbul ignore next */Alert.install = function(Vue) {  Vue.component(Alert.name, Alert);};export default Alert;

登录后复制

除了上述内容之外,还有几点值得我们注意一下:

插件传入的如果是一个对象,则执行其install方法,如果是一个函数,则执行它自身,并bind this为null,然后传入额外的参数

if (typeof plugin.install === 'function') {  plugin.install.apply(plugin, args);} else if (typeof plugin === 'function') {  plugin.apply(null, args);}

登录后复制如果插件没有被注册过,那么注册成功之后会给插件添加一个installed的属性,其值为true。Vue.use方法内部会检测插件的installed属性,从而避免重复注册插件

Vue.use其实并不神秘,内部还是我们平时使用的这些东西,仅仅只是给他们套上了一层高端的外衣而已。我们在开发中,也可以尝试使用这种方式,不仅简单,而且有逼格。

相关推荐:2020年前端vue面试题大汇总(附答案)vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程入门!!

以上就是浅谈Vue.use到底是什么?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3023090.html

(0)
上一篇 2025年3月13日 06:02:43
下一篇 2025年3月2日 22:00:43

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 浅谈Vue.js中双向绑定的原理及实现方法

    Vue最独特的特性之一,是其非侵入性的响应式系统。数据模型仅仅是普通的JavaScript对象。而当你修改它们时,视图会进行更新。vue通过双向绑定实现,本文就来为大家介绍一下vue双向绑定原理及实现方法。 本文主要介绍两大内容: 1. v…

    2025年3月13日 编程技术
    200
  • 详解vue.js中如何处理事件

    下面vue.js教程给大家介绍一下使用vue.js处理事件的方法,希望对大家有一定的帮助。 当您使用Vue构建动态网站时,您很可能希望它能够响应事件。 例如,如果用户单击按钮,提交表单,甚至只是移动鼠标,您可能希望您的Vue网站以某种方式做…

    2025年3月13日
    200
  • 实现带有进度条的Vue延迟加载

    下面vue.js栏目给大家介绍一下给vue的惰性加载添加进度条的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 简介 通常用 Vue.js 编写单页应用(SPA)时,当加载页面时,所有必需的资源(如 JavaScri…

    2025年3月13日
    200
  • 浅谈vue-cli初始化Vue项目的项目结构

    概述 vue-cli是vue 提供的一个官方命令行工具,可用于快速搭建大型单页应用。该工具提供开箱即用的构建工具配置,带来现代化的前端开发流程。只需几分钟即可创建并启动一个带热重载、保存时静态检查以及可用于生产环境的构建配置的项目。 使用v…

    2025年3月13日 编程技术
    200
  • 分析一下Vue.use的源码

    有过vue开发经验的,对于vue.use并不陌生。当使用vue-resource或vue-router等全局组件时,必须通过Vue.use方法引入,才起作用。那么vue.use在组件引入之前到底做了那些事情呢? 先上vue.use源码 Vu…

    2025年3月13日
    200
  • vue.js中如何使用v-for以及怎么获取索引?

    下面vue.js教程栏目带大家了解一下vue.js中v-for的使用及索引获取。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 登录后复制   变化如下: el处需id,写body报错;参数index需写在item后面;作…

    2025年3月13日
    200
  • 了解vue.js中的常用指令(总结)

    v-text v-text主要用来更新textContent,可以等同于JS的text属性。 // 等同于下方语句: {{text}} 登录后复制 v-html 双大括号的方式会将数据解释为纯文本,而非HTML。为了输出真正的HTML,可以…

    2025年3月13日
    200
  • vue.js图片怎么渲染

    vue.js渲染图片的方法:首先初始化列表;然后获取上个页面带过来的参数,获取api,app,foot;接着向后传递参数;最后渲染本地图片。 【相关文章推荐:vue.js】 vue.js渲染图片的方法: 带参数传值 本地美食 立即学习“前端…

    2025年3月13日
    200
  • vue.js打包后图片路径错误怎么办

    vue.js打包后图片路径错误的解决办法:1、修改【assetsPublicPath: ‘./’】;2、打开【webpack.prod.conf.js】,在output增加【publicPath: ‘./…

    2025年3月13日 编程技术
    200
  • vue项目能直接引入vue.js吗

    vue项目能直接引入vue.js,引入方法:1、是使用脚手架工具【vue-cli】;2、二是直接在项目引入【vue.js】,代码为【var vm = new Vue({el: ‘#accountManage’,dat…

    2025年3月13日
    200

发表回复

登录后才能评论