欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-12-08 12:15:07
全局注册,注册的组件需要在初始化根实例之前注册了组件; 局部注册,通过使用组件实例选项注册,可以使组件仅在另一个组件或者实例的作用域中可用: 全局组件 js...

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

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

全局组件

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 组件 全局注册和局部注册的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。