zoukankan      html  css  js  c++  java
  • Vue混合

    gitHub地址: https://github.com/manlili/vue_learn里面lesson13

    一 定位

    混合以一种灵活的方式为组件提供分布复用功能。混合对象可以包含任意的组件选项。当组件使用了混合对象时,混合对象的所有选项将被“混入”组件自己的选项中。

    实际上,我也没搞懂这句话,先研究再说,放个一年也许就自己慢慢懂了,时间这玩意可以发酵

    二 定义

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Vue混合--定义</title>
            <script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
            <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
        </head>
        <body>
            <script type="text/javascript">
                var myMinxin= {             //第一步,创建一个混合数据
                    created: function () {
                        this.hello();
                    },
                    methods: {
                        hello: function () {
                            alert('你好');
                        }
                    }
                }
                
                var myComponent = Vue.extend({    //将混合注册到Vue
                    mixins: [myMinxin]
                })
                
                new myComponent();    //实例化这个混合
            </script>
        </body>
    </html>

    上面代码,弹出:

    三 混合与Vue同名冲突

    混合对象与组件包含同名选项时,这些选项将以适当的策略合并。例如,同名钩子函数被并入一个数组,因而都会被调用。另外,混合的钩子将在组件自己的钩子之前调用。

    同名钩子函数冲突,代码如下:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Vue混合--同名冲突</title>
            <script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
            <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
        </head>
        <body>
            <script type="text/javascript">
                var myMinxin= {             //第一步,创建一个混合数据
                    created: function () {
                        this.hello();
                    },
                    methods: {
                        hello: function () {
                            alert('你好');
                        }
                    }
                }
                
                var myComponent = Vue.extend({    //注意Vue的created与minxin的created重合,这里将先执行minxin的created
                    created: function () {
                        alert('我是Vue的created');
                    },
                    mixins: [myMinxin]
                })
                
                new myComponent();    //实例化这个混合
            </script>
        </body>
    </html>

    先弹出:

    再弹出:

     值为对象同名冲突,代码如下:

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Vue混合--同名冲突</title>
            <script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
            <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
        </head>
        <body>
            <script type="text/javascript">
                var myMinxin= {             //第一步,创建一个混合数据
                    created: function () {
                        this.hello();
                        this.nono();
                    },
                    methods: {
                        hello: function () {
                            alert('你好1');
                        },
                        nono: function () {
                            alert('nono1');
                        }
                    }
                }
                
                var myComponent = Vue.extend({     //methods中对象冲突,只显示Vue实例中的方法
                    created: function () {
                        this.hello();
                        this.nono();
                    },
                    mixins: [myMinxin],
                    methods: {
                        hello: function () {
                            alert('你好2');
                        },
                        nono: function () {
                            alert('nono2');
                        }
                    }
                })
                
                new myComponent();    //实例化这个混合
            </script>
        </body>
    </html>

    输出如下:

     

  • 相关阅读:
    给元素查索引
    数组的反转和排序
    本地修改文件到git
    +new Date()
    文字双层投影
    表格组件 自定义宽度 设置 span 内容 超出省略号
    iframe的使用
    分页获取列表进行索引累加
    日期时间格式化
    柱状echarts 自定义图例设置
  • 原文地址:https://www.cnblogs.com/lily1010/p/5846590.html
Copyright © 2011-2022 走看看