详解Vue2.0组件的继承与扩展


Posted in Javascript onNovember 23, 2018

前言

本文将介绍vue2.0中的组件的继承与扩展,主要分享slot、mixins/extends和extend的用法。

一、slot

1.默认插槽和匿名插槽

slot用来获取组件中的原内容,此方式用于父组件向子组件传递“标签数据”。有的时候为插槽提供默认的内容是很有用的,例如,一个<my-hello> 组件可能希望这个按钮的默认内容是“如果没有原内容,则显示该内容”,但是同时允许用户覆写为别的内容。

<body>
 <div id="itany">
 <my-hello>180812</my-hello>
 </div>
<template id="hello">
 <div>
 <h3>welcome to xiamen</h3>
 <slot>如果没有原内容,则显示该内容</slot>// 默认插槽
 </div>
</template>
<script>
 var vm=new Vue({
  el:'#itany',
  components:{
  'my-hello':{
  template:'#hello'
 }
  }
 }); 
</script>

详解Vue2.0组件的继承与扩展

2.具名插槽

有些时候我们需要多个插槽,<slot> 元素有一个特殊的特性:name。这个特性可以用来定义额外的插槽:

<div id="itany">
 <my-hello>
  <ul slot="s1">
 <li>aaa</li>
 <li>bbb</li>
 <li>ccc</li>
  </ul>
  <ol slot="s2">
 <li>111</li>
 <li>222</li>
 <li>333</li>
  </ol>
 </my-hello>
</div>
<template id="hello">
 <div>
  <slot name="s2"></slot>
  <h3>welcome to xiamen</h3>
  <slot name="s1"></slot>
 </div>
</template>
<script>
 var vm=new Vue({
 el:'#itany',
 components:{
  'my-hello':{
   template:'#hello'
  }
 }
 }); 
</script>

详解Vue2.0组件的继承与扩展

二、mixins

1.mixins简介

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

2.mixins用途

一般有两种用途:

1、在你已经写好了构造器后,需要增加方法或者临时的活动时使用的方法,这时用混入会减少源代码的污染。

2、很多地方都会用到的公用方法,用混入的方法可以减少代码量,实现代码重用。

例如下面的例子:实现每次数据变化时都能够在控制台打印出提示:"数据发生变化"

<h1>Mixins</h1>
 <hr>
 <div id="app">
  <p>num:{{ num }}</p>
  <P>
   <button @click="add">增加数量<tton>
  </P>
 </div>
 <script type="text/javascript">
  var addLog = { //额外临时加入时,用于显示日志
   updated: function () {
    console.log("数据发生变化,变化成" + this.num + ".");
   }
  }
  Vue.mixin({// 全局注册一个混入,影响注册之后所有创建的每个 Vue 实例
   updated: function () {
    console.log("我是全局的混入")
   }
  })
  var app = new Vue({
   el: '#app',
   data: {
    num: 1
   },
   methods: {
    add: function () {
     this.num++;
    }
   },
   updated() {
    console.log("我是原生的update")
   },
   mixins: [addLog]//混入
  })

详解Vue2.0组件的继承与扩展

3.mixins的调用顺序

上例说明了:从执行的先后顺序来说,混入对象的钩子将在组件自身钩子之前调用,如果遇到全局混入(Vue.mixin),全局混入的执行顺序要前于混入和组件里的方法。

三、extends

1.extends用法

extends选项允许声明扩展另一个组件,而无需使用 Vue.extend
通过外部增加对象的形式,对构造器进行扩展。它和混入mixins非常的类似。只不过接收的参数是简单的选项对象或构造函数,所以extends只能单次扩展一个组件。

<h1>Extends</h1>
 <hr>
 <div id="app">
  num:{{ num }}
  <p>
   <button @click="add">add</button>
  </p>
 </div>
 <script type="text/javascript">
  var bbb = {
   updated() {
    console.log("我是被扩展出来的");
   },
   methods: {
    add: function () { //跟原生的方法冲突,取原生的方法,这点跟混入一样
     console.log('我是被扩展出来的add方法!');
     this.num++;
    }
   }
  };
  var app = new Vue({
   el: '#app',
   data: {
    num: 1
   },
   methods: {
    add: function () {
     console.log('我是原生add方法');
     this.num++;
    }
   },
   updated() {
    console.log("我是扩展出来的");
   },
   extends: bbb// 接收对象和函数
  })

详解Vue2.0组件的继承与扩展

从上面的例子也可看出,执行的先后顺序和mixins一样,另外扩展的方法与原生的冲突时,扩展的方法不生效,这点跟混入一样。

2.extends和mixins优先级比较

var extend={
 data:{extendData:'我是extend的data'},
 created:function(){
  console.log('这是extend的created');
 }
 }
 var mixin={
 data:{mixinData:'我是mixin的data'},
 created:function(){
  console.log('这是mixin的created');
 }
 }
 var vm=new Vue({
 el:'#app',
 data:{mixinData:'我是vue实例的data'},
 created:function(){
  console.log('这是vue实例的created');
 },
 methods:{
  getSum:function(){
  console.log('这是vue实例里面getSum的方法');
  }
 },
 mixins:[mixin],
 extends:extend
 })

详解Vue2.0组件的继承与扩展

由此可以得出,相对于mixins,extends触发的优先级更高

四、extend

Vue.extend只是创建一个构造器,它是为了创建可复用的组件。其主要用来服务于Vue.component,用来生成组件

<div id="itany">
  <hello></hello>
  <my-world></my-world>
 </div>
 <script>
  /**
   * 方式1:先创建组件构造器,然后由组件构造器创建组件
   */
  //1.使用Vue.extend()创建一个组件构造器
  var MyComponent = Vue.extend({
   template: '<h3>Hello World</h3>'
  });
  //2.使用Vue.component(标签名,组件构造器),根据组件构造器来创建组件
  Vue.component('hello', MyComponent);
  /**
   * 方式2:直接创建组件(推荐)
   */
  // Vue.component('world',{
  Vue.component('my-world', {
   template: '<h1>你好,世界</h1>'
  });
  var vm = new Vue({ //这里的vm也是一个组件,称为根组件Root
   el: '#itany',
   data: {}
  }); 
 </script>

如果有需要源代码,请猛戳源代码

参考文章

Vue官方文档

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 调整select 位置的函数
Feb 21 Javascript
javascript URL锚点取值方法
Feb 25 Javascript
jQuery jqgrid 对含特殊字符json 数据的 Java 处理方法
Jan 01 Javascript
基于jquery的高性能td和input切换并可修改内容实现代码
Jan 09 Javascript
博客侧边栏模块跟随滚动条滑动固定效果的实现方法(js+jquery等)
Mar 24 Javascript
js给onclick事件赋值,动态传参数实例解说
Mar 28 Javascript
jQuery实现div浮动层跟随页面滚动效果
Feb 11 Javascript
jQuery Mobile框架中的表单组件基础使用教程
May 17 Javascript
Vue.js第三天学习笔记(计算属性computed)
Dec 01 Javascript
Node.js设置CORS跨域请求中多域名白名单的方法
Mar 28 Javascript
Vue js 的生命周期(看了就懂)(推荐)
Mar 29 Javascript
原生js+ajax分页组件
Jan 30 Javascript
angular4自定义表单控件[(ngModel)]的实现
Nov 23 #Javascript
详解Angular中实现自定义组件的双向绑定的两种方法
Nov 23 #Javascript
Vue.js组件间通信方式总结【推荐】
Nov 23 #Javascript
vue-cli 2.*中导入公共less文件的方法步骤
Nov 22 #Javascript
vue全局使用axios的方法实例详解
Nov 22 #Javascript
vue中的ref和$refs的使用
Nov 22 #Javascript
浅析vue 函数配置项watch及函数 $watch 源码分享
Nov 22 #Javascript
You might like
PHP4实际应用经验篇(5)
2006/10/09 PHP
php 表单验证实现代码
2009/03/10 PHP
PHP网站备份程序代码分享
2011/06/10 PHP
php通过获取头信息判断图片类型的方法
2015/06/26 PHP
CI框架使用composer安装的依赖包步骤与方法分析
2016/11/21 PHP
ajax+php实现无刷新验证手机号的实例
2017/12/22 PHP
PHP 并发场景的几种解决方案
2019/06/14 PHP
[原创]来自ImageSee官方 JavaScript图片浏览器
2008/01/16 Javascript
js实现单一html页面两套css切换代码
2013/04/11 Javascript
jquery通过visible来判断标签是否显示或隐藏
2014/05/08 Javascript
jquery实现可拖拽弹出层特效
2015/01/04 Javascript
简单谈谈javascript Date类型
2015/09/06 Javascript
JS简单实现禁止访问某个页面的方法
2016/09/13 Javascript
node.js爬虫爬取拉勾网职位信息
2017/03/14 Javascript
详解JS模块导入导出
2017/12/20 Javascript
JavaScript 反射和属性赋值实例解析
2019/10/28 Javascript
[03:07]2015国际邀请赛选手档案EHOME.rOtK 是什么让他落泪?
2015/07/31 DOTA
[43:43]完美世界DOTA2联赛PWL S2 FTD.C vs Rebirth 第一场 11.22
2020/11/24 DOTA
[02:16]完美世界DOTA2联赛PWL S3 集锦第三期
2020/12/21 DOTA
python设置windows桌面壁纸的实现代码
2013/01/28 Python
详解Django-restframework 之频率源码分析
2019/02/27 Python
numpy:找到指定元素的索引示例
2019/11/26 Python
CSS3中的弹性布局em运用入门详解 1em等于多少像素
2021/02/08 HTML / CSS
英国家喻户晓的折扣商场:TK Maxx
2017/05/26 全球购物
关于期中考试的反思
2014/02/02 职场文书
化妆师职业生涯规划书
2014/02/16 职场文书
自主招生教师推荐信
2014/05/10 职场文书
纪检干部先进事迹材料
2014/08/23 职场文书
加强干部作风建设整改方案
2014/10/24 职场文书
民主评议政风行风活动心得体会
2014/10/29 职场文书
三行辞职书范文
2015/02/26 职场文书
2015年幼儿园中班开学寄语
2015/05/27 职场文书
交通事故责任认定书
2015/08/06 职场文书
学校就业保障协议书
2019/06/24 职场文书
Java 实战项目之家居购物商城系统详解流程
2021/11/11 Java/Android
Win11应用商店打开闪退怎么解决? win11应用商店打不开的多种解决办法
2022/04/05 数码科技