vue.js之mixins混合

来源:互联网 发布:excel编程常用代码 编辑:程序博客网 时间:2024/05/15 14:15

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

一、Mixins的基本用法

现在有个数字点击递增的程序,假设已经完成了,这时我们希望每次数据变化时都能够在控制台打印出提示:“数据发生变化”.

代码实现过程:

<div id="app">    <p>num:{{ num }}</p>    <P><button @click="add">增加数量</button></P></div><script>    var addLog = {        updated : function () {            console.log("数据放生变化,变化成" + this.num + ".");        }    }    var app = new Vue({        el: '#app',        data: {            num: 1        },        methods: {            add: function () {                this.num++;            }        },        mixins: [addLog], //混入    })<script>     

这里写图片描述

当点击按钮时会触发混入的 addLog 中的 updated 方法。


二、mixins的调用顺序

从执行的先后顺序来说,都是混入的先执行,然后构造器里的再执行,需要注意的是,这并不是方法的覆盖,而是被执行了两遍。

在上边的代码的构造器里我们也加入了updated的钩子函数:

<div id="app">    <p>num:{{ num }}</p>    <P><button @click="add">增加数量</button></P></div><script>    var addLog = {        updated : function () {            console.log("数据放生变化,变化成" + this.num + ".");        }    }    var app = new Vue({        el: '#app',        data: {            num: 1        },        methods: {            add: function () {                this.num++;            }        },        updated: function () {            console.log("构造器里的updated方法。")        },        mixins: [addLog], //混入    })</script>     

这里写图片描述


三、全局混入方式

全局混入的执行顺序要前于混入和构造器里的方法。

<div id="app">    <p>num:{{ num }}</p>    <P><button @click="add">增加数量</button></P></div><script>    Vue.mixin({        updated: function () {            console.log('我是全局被混入的');        }    })    var addLog = {        updated : function () {            console.log("数据放生变化,变化成" + this.num + ".");        }    }    var app = new Vue({        el: '#app',        data: {            num: 1        },        methods: {            add: function () {                this.num++;            }        },        updated: function () {            console.log("构造器里的updated方法。")        },        mixins: [addLog], //混入    })</script>     

这里写图片描述

顺序总结:全局混入优先于局部混入,局部混入优先于构造器


两个对象键名冲突时,取组件对象的键值对

当混入和组件对象中都有test方法(重名)时,最终的值取组件对象的键值对

  <div id="app">      <p>num:{{ num }}</p>      <P>          <button @click="add">增加数量</button>      </P>  </div>  <script>      var addLog = {          updated: function () {              console.log("数据放生变化,变化成" + this.num + ".");              this.test();          },          methods: {              test: function () {                  console.log('混入中的test')              }          }      }      var app = new Vue({          el: '#app',          data: {              num: 1          },          methods: {              add: function () {                  this.num++;              },              test:function(){                  console.log('组件对象中的test')              }          },          mixins: [addLog], //混入      })</script>

这里写图片描述

原创粉丝点击