温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Vue3.0插件执行原理是什么

发布时间:2022-02-07 14:44:14 来源:亿速云 阅读:202 作者:iii 栏目:开发技术

这篇文章主要介绍“Vue3.0插件执行原理是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue3.0插件执行原理是什么”文章能帮助大家解决问题。

    一、编写插件

    Vue项目能够使用很多插件来丰富自己的功能,例如Vue-Router、Vuex……,这么多插件供我们使用,节省了我们大量的人力和物力,那这些插件是开发出来的呢?是不是我们自己也想拥有一个属于自己的vue插件,下面就展示一下如何写一个自己的Vue插件。

    1.1 包含install()方法的Object

    Vue插件可以是一个包含install方法的Object对象,此时插件被调用时会调用install方法,

    如下所示:

    export default {
        // 接收两个参数
        // app: 应用上下文的实例
        // options:插件输入的选项
        install: (app, options) => {
            console.log('app', app);
            console.log('options', options);
            // 做一些处理
            // ……
        }
    }

    1.2 通过function的方式

    Vue插件也可以是一个function函数,此时插件被调用时会调用function函数本身,

    如下所示:

    export default function TestPlugin(app, options) {
        console.log('app', app);
        console.log('options', options);
    }

    二、使用插件

    上述已经阐述了如何编写自己的插件,插件编写完了之后就需要使用这些插件了,那这些插件应该如何使用呢?其实用起来很简单,应用上下文的实例上提供了对应的use方法。

    app.use(plugin, [options]); // 返回一个应用实例,所以其可以链式添加新的插件

    三、app.use()是如何执行插件的

    为什么app.use()可以使用这些插件呢?本着“知其然而知其所以然”的精神,一起来扒一扒为什么。如下是对应的源码:

    function createApp(rootComponent, rootProps = null) {
        // ……
        const installedPlugins = new Set();
        const app = (context.app = {
            // ……
            use(plugin, ...options) {
                if (installedPlugins.has(plugin)) {
                    warn(`Plugin has already been applied to target app.`);
                }
                else if (plugin && shared.isFunction(plugin.install)) {
                    installedPlugins.add(plugin);
                    plugin.install(app, ...options);
                }
                else if (shared.isFunction(plugin)) {
                    installedPlugins.add(plugin);
                    plugin(app, ...options);
                }
                else {
                    warn(`A plugin must either be a function or an object with an "install" ` +
                        `function.`);
                }
                return app;
            },
            // ……
        });
        return app;
    };

    上述代码读起来很简单,其实现了以下几件事情:

    • 利用Set结构存储插件,当存在该插件时抛出异常;

    • 通过判断是否存在install方法或是否是函数,执行对应的插件;

    • 执行插件时将app上下文实例和options作为参数传入;

    关于“Vue3.0插件执行原理是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注亿速云行业资讯频道,小编每天都会为大家更新不同的知识点。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    vue
    AI