1. 混入

概述:

混入(mixins)是一种分发Vue组件中可复用功能的非常灵活的方式。混入对象可以包含任意组件选项。当组件使用混入对象时,所有混入对象的选项将被混入该组件本身的选项。

简单来说,混入用于公共代码复用。

混入分为:全局和局部。

混入的执行顺序:

<div id="app">
    <h3>{{name}}</h3>
    <hr>
    <h3>{{showName}}</h3>
    <hr>
    <div>{{run()}}</div>
</div>
<script>
    // 混入:用于公共代码复用
    // 方式  全局  局部
    Vue.mixin({
        // data混入
        data() {
            return {
                name: '张三 -- 全局'
            }
        },
        // 计算属性混入
        computed: {
            showName() {
                return 'abc -- 全局'
            }
        },
        methods: {
            run() {
                return 'run -- 全局'
            }
        },
        // 生命周期方法混入
        created() {
            console.log('created -- 全局');
        }
    })
    // 局部混入
    const mix = {
        data() {
            return {
                name: '张三 -- 局部'
            }
        },
        computed: {
            showName() {
                return 'abc -- 局部'
            }
        },
        methods: {
            run() {
                return 'run -- 局部'
            }
        },
        created() {
            console.log('created -- 局部');
        }
    }
    const vm = new Vue({
        el: '#app',
        data: {
            // name: '张三 -- 实例'
        },
        // 局部混入调用,可以调用 n 个
        mixins: [mix],
        methods: {
            run() {
                return 'run -- 实例'
            }
        },
        created() {
            console.log('created -- 实例');
        }
    })
</script>

注意:

  1. 混入的配置,可以把几乎所有new Vue配置中的所有配置都能混入,但是el配置它不可以混入
  2. data配置,在混入方式中,只能写函数的方式,且函数一定要返回一个对象,混入可能被调用多次,如果直接是对象的话,就会有污染(调用多次,引用地址却不变,实例之间调用时不会互相影响)
  3. data混入的优先级(对象属性) 组件(实例) > 局部 > 全局 => 只会调用一个
  4. 生命周期方法,执行顺序 全局 -> 局部 --> 组件(实例) 依次执行
  5. 方法依次执行,属性对应的配置只执行一次,data是例外

2. 插件

概述:

在vue中提供插件机制,可以通过它的要求来完成插件的封装,运用到项目中

语法:

Vue.use(函数|类|对象,[可选参数])

// 函数
// 函数名称 plugin 可以更换
function plugin(Vue类,options可选参数){}
// 类
class Plugin {
	// 必须是静态方法,且名称必须为install
	static install(Vue类,options可选参数){}
}
// 调用静态属性:Plugin.install(Vue类,options可选参数)
// 对象
const obj = {
	// 属性名称必须为 install
	install(Vue类,options可选参数){}
}

案例:

<div id="app">
    <h3 v-red>{{title}}</h3>
</div>
<script>
    // 它是就一个模块
    function plugin(Vue, options) {
        console.log(options);
        // 这是一个指令
        Vue.directive('red', el => {
            el.style.cssText = 'color:red'
        })
        // 这是混入
        Vue.mixin({
            data() {
                return {
                    title: `() => console.log('run');`
                }
            },
            // 这是生命周期方法
            created() {
                this.title = options.title
                console.log('混入了');
            }
        })
        // 静态属性
        Vue.run = () => console.log('run');
        // 添加成员属性
        Vue.prototype.play = () => console.log('play');
    }
    // 插入插件,可以插入参数
    Vue.use(plugin, { title: 'abc' })
    const vm = new Vue({
        el: '#app',
        data: {
        },
        created() {
            Vue.run()
            this.play()
        }
    })
</script>

插件封装成类:

<div id="app">
    <h3 v-red>{{title}}</h3>
</div>
<script>
    class Plugin {
        // 它是就一个模块
        static install(Vue, options) {
            console.log(options);
            Vue.directive('red', el => {
                el.style.cssText = 'color:red'
            })
            Vue.mixin({
                data() {
                    return {
                        title: `() => console.log('run');`
                    }
                },
                created() {
                    this.title = options.title
                    console.log('混入了');
                }
            })
            // 添加成员属性
            Vue.prototype.run = () => console.log('run');
        }
    }
    // 插入插件
    Vue.use(Plugin, { title: 'abc' })
    const vm = new Vue({
        el: '#app',
        data: {
        },
        created() {
            this.run()
        }
    })
</script>

插件封装成对象:

<div id="app">
    <h3 v-red>{{title}}</h3>
</div>
<script>
    const Plugin = {
        install(Vue, options) {
            console.log(options);
            Vue.directive('red', el => {
                el.style.cssText = 'color:red'
            })
            Vue.mixin({
                data() {
                    return {
                        title: `() => console.log('run');`
                    }
                },
                created() {
                    this.title = options.title
                    console.log('混入了');
                }
            })
            // 添加成员属性
            Vue.prototype.run = () => console.log('run');
        }
    }
    // 插入插件
    Vue.use(Plugin, { title: 'abc' })
    const vm = new Vue({
        el: '#app',
        data: {
        },
        created() {
            this.run()
        }
    })
</script>

到此这篇关于Vue混入与插件的使用介绍的文章就介绍到这了,更多相关Vue混入与插件内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

Vue混入与插件的使用介绍的更多相关文章

  1. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  2. vue自定义加载指令v-loading占位图指令v-showimg

    这篇文章主要为大家介绍了vue自定义加载指令和v-loading占位图指令v-showimg的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  3. vue使用动画实现滚动表格效果

    这篇文章主要为大家详细介绍了vue使用动画实现滚动表格效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  4. 关于Vue 监控数组的问题

    这篇文章主要介绍了Vue 监控数组的示例,主要包括Vue 是如何追踪数据发生变化,Vue 如何更新数组以及为什么有些数组的数据变更不能被 Vue 监测到,对vue监控数组知识是面试比较常见的问题,感兴趣的朋友一起看看吧

  5. Vue子组件props从父组件接收数据并存入data

    这篇文章主要介绍了Vue子组件props从父组件接收数据并存入data的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  6. Vue h函数的使用详解

    本文主要介绍了Vue h函数的使用详解,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  7. VUE响应式原理的实现详解

    这篇文章主要为大家详细介绍了VUE响应式原理的实现,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

  8. vue+Element ui实现照片墙效果

    这篇文章主要为大家详细介绍了vue+Element ui实现照片墙效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. vue+elemet实现表格手动合并行列

    这篇文章主要为大家详细介绍了vue+elemet实现表格手动合并行列,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. iview+vue实现导入EXCEL预览功能

    这篇文章主要为大家详细介绍了iview+vue实现导入EXCEL预览功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

随机推荐

  1. js中‘!.’是什么意思

  2. Vue如何指定不编译的文件夹和favicon.ico

    这篇文章主要介绍了Vue如何指定不编译的文件夹和favicon.ico,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

  3. 基于JavaScript编写一个图片转PDF转换器

    本文为大家介绍了一个简单的 JavaScript 项目,可以将图片转换为 PDF 文件。你可以从本地选择任何一张图片,只需点击一下即可将其转换为 PDF 文件,感兴趣的可以动手尝试一下

  4. jquery点赞功能实现代码 点个赞吧!

    点赞功能很多地方都会出现,如何实现爱心点赞功能,这篇文章主要为大家详细介绍了jquery点赞功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  5. AngularJs上传前预览图片的实例代码

    使用AngularJs进行开发,在项目中,经常会遇到上传图片后,需在一旁预览图片内容,怎么实现这样的功能呢?今天小编给大家分享AugularJs上传前预览图片的实现代码,需要的朋友参考下吧

  6. JavaScript面向对象编程入门教程

    这篇文章主要介绍了JavaScript面向对象编程的相关概念,例如类、对象、属性、方法等面向对象的术语,并以实例讲解各种术语的使用,非常好的一篇面向对象入门教程,其它语言也可以参考哦

  7. jQuery中的通配符选择器使用总结

    通配符在控制input标签时相当好用,这里简单进行了jQuery中的通配符选择器使用总结,需要的朋友可以参考下

  8. javascript 动态调整图片尺寸实现代码

    在自己的网站上更新文章时一个比较常见的问题是:文章插图太宽,使整个网页都变形了。如果对每个插图都先进行缩放再插入的话,太麻烦了。

  9. jquery ajaxfileupload异步上传插件

    这篇文章主要为大家详细介绍了jquery ajaxfileupload异步上传插件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. React学习之受控组件与数据共享实例分析

    这篇文章主要介绍了React学习之受控组件与数据共享,结合实例形式分析了React受控组件与组件间数据共享相关原理与使用技巧,需要的朋友可以参考下

返回
顶部