vue 组件 全局注册和局部注册的实现


Posted in Javascript onFebruary 28, 2018

全局注册,注册的组件需要在初始化根实例之前注册了组件;

局部注册,通过使用组件实例选项注册,可以使组件仅在另一个组件或者实例的作用域中可用:

全局组件

js

Vue.component('tab-title',{
   props:['title'],
   template:'<li v-on:click="$emit(\'change\')">{{title}}</li>'
 })
 Vue.component('tab-content',{
   props:['content'],
   template:'<div>{{content}}</div>'
 })

局部组件demo:

html

<div id="app">
  <ul class="navTab">
   <li v-for="(navTab,index) in navTabs" is="tab-title" v-bind:info="navTab.text" v-bind:class="{active:navTab.isActive}" v-on:addactive="switchActive(index)"></li>
  </ul>
  <div class="tabContent">
   <div v-for="navTab in navTabs" is="tab-content" v-bind:content="navTab.tabContent" 
   v-bind:class="['tab-panel',{active:navTab.isActive}]" v-if="navTab.isActive"></div>
  </div>
  </div>

js

var app=new Vue({
      el: '#app',
     components: {
       'tab-title': {
        props:['info'],//接受父元素传递的参数
        template:'<li v-on:click="$emit(\'addactive\')">{{info}}</li>'//点击时传递通过$emit子元素传递给父元素调用 addactive方法(不能使用驼峰写法)
        },
       'tab-content':{
         props:["content"],
        template:'<div>{{content}}</div>'
       }
     },
     methods:{
       switchActive:function(index){
        for(var i=0;i<this.navTabs.length;i++){
         this.navTabs[i].isActive=false;
        }
        this.navTabs[index].isActive=true;
        
       }
     },
     data:{
      navTabs:[
       {
        text:"tab1",
        isActive:true,
        tabContent:'this is tab1 content'
       },
       {
        text:"tab2",
        isActive:false,
        tabContent:'this is tab2 content'
       },
       {
        text:"tab3",
        isActive:false,
        tabContent:'this is tab3 content'
       }
      ]
     }
    });

组件实例的作用域是孤立的。这意味着不能再子组件的模板内直接引用父组件的数据。要让子组件可以使用父组件的数据,我们需要通过子组件的props选项。

子组件要显式地用 props 选项声明它期待获得的数据

在模板中,要动态地绑定父组件的数据到字模板的props,与绑定到任何普通的HTMO特性相类似。就是使用 v-bind。每当父组件的数据变化时,该变化也会传递给子组件:

所有的vuejs组件都是被扩展的vue实例

每一个Vue实例都会代理这个实例的data属性对象里的所有的属性

所有的Vue实例本身保罗的属性和方法,都以$开头来区别,对应Vue.set

例如:

vm.$data

vm.$methods

vm.$watch

这个有利于和data属性对象的数据来区分

多有的指令都以v-xxx形式存在:

以上这篇vue 组件 全局注册和局部注册的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript-Mozilla和IE中的一个函数直接量的问题
Jan 09 Javascript
将list转换为json失败的原因
Dec 17 Javascript
Node.js入门教程:在windows和Linux上安装配置Node.js图文教程
Aug 14 Javascript
js父页面与子页面不同时显示的方法
Oct 16 Javascript
JS+CSS实现大气清新的滑动菜单效果代码
Oct 22 Javascript
JavaScript的Number对象的toString()方法
Dec 18 Javascript
浅谈javascript基础之客户端事件驱动
Jun 10 Javascript
JQuery PHP图片在线裁剪实例
Jul 27 Javascript
jquery 仿锚点跳转到页面指定位置的实例
Feb 14 Javascript
JS实现图片拖拽交换效果
Nov 30 Javascript
vue-router结合vuex实现用户权限控制功能
Nov 14 Javascript
解决Vue+SpringBoot+Shiro跨域问题
Jun 09 Vue.js
vue 自定义全局方法,在组件里面的使用介绍
Feb 28 #Javascript
Vue2.0子同级组件之间数据交互方法
Feb 28 #Javascript
bootstrap table支持高度百分比的实例代码
Feb 28 #Javascript
vue 2.x 中axios 封装的get 和post方法
Feb 28 #Javascript
浅析node应用的timing-attack安全漏洞
Feb 28 #Javascript
vue组件传递对象中实现单向绑定的示例
Feb 28 #Javascript
在Vue组件中使用 TypeScript的方法
Feb 28 #Javascript
You might like
关于PHP5 Session生命周期介绍
2010/03/02 PHP
PHP采用get获取url汉字出现乱码的解决方法
2014/11/13 PHP
php简单截取字符串代码示例
2016/10/19 PHP
通过chrome浏览器控制台(Console)进行PHP Debug的方法
2016/10/19 PHP
PHP定义字符串的四种方式详解
2018/02/06 PHP
jQuery EasyUI API 中文文档 - MenuButton菜单按钮使用介绍
2011/10/06 Javascript
模拟电子签章盖章效果的jQuery插件源码
2013/06/24 Javascript
SeaJS入门教程系列之SeaJS介绍(一)
2014/03/03 Javascript
javascript控制在光标位置插入文字适合表情的插入
2014/06/09 Javascript
分享一则javascript 调试技巧
2015/01/02 Javascript
jQuery组件easyui基本布局实现代码
2016/08/25 Javascript
浅谈javascript中的三种弹窗
2016/10/21 Javascript
概述如何实现一个简单的浏览器端js模块加载器
2016/12/07 Javascript
js定时器实例分享
2016/12/20 Javascript
vue.js开发实现全局调用的MessageBox组件实例代码
2017/11/22 Javascript
详解vue 计算属性与方法跟侦听器区别(面试考点)
2018/04/23 Javascript
Vue实现表格中对数据进行转换、处理的方法
2018/09/06 Javascript
Vue filter格式化时间戳时间成标准日期格式的方法
2018/09/16 Javascript
JQuery获取可视区尺寸和文档尺寸及制作悬浮菜单示例
2019/05/14 jQuery
详解JavaScript 浮点数运算的精度问题
2019/07/23 Javascript
python实现根据用户输入从电影网站获取影片信息的方法
2015/04/07 Python
linecache模块加载和缓存文件内容详解
2018/01/11 Python
使用Python如何测试InnoDB与MyISAM的读写性能
2018/09/18 Python
解决django前后端分离csrf验证的问题
2019/02/03 Python
谈一谈基于python的面向对象编程基础
2019/05/21 Python
Python 获取numpy.array索引值的实例
2019/12/06 Python
通过python检测字符串的字母
2020/02/18 Python
一文读懂Python 枚举
2020/08/25 Python
纪念建党演讲稿范文
2014/01/13 职场文书
助人为乐表扬信范文
2014/01/14 职场文书
2014党员整改措施思想汇报
2014/10/07 职场文书
教育见习报告范文
2014/11/03 职场文书
小学教师教学随笔
2015/08/14 职场文书
SQL 尚未定义空闲 CPU 条件 - OnIdle 作业计划将不起任何作用
2021/06/30 SQL Server
MYSQL优化之数据表碎片整理详解
2022/04/03 MySQL
海弦WR-800F
2022/04/05 无线电