首页 > 语言 > JavaScript > 正文

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

2024-05-06 15:21:18
字体:
来源:转载
供稿:网友

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

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

全局组件

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形式存在:

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选