• 技术文章 >web前端 >js教程

    vue全局注册和局部注册使用详解

    php中世界最好的语言php中世界最好的语言2018-04-12 15:34:13原创1213

    这次给大家带来vue全局注册和局部注册使用详解,使用vue全局注册和局部的注意事项有哪些,下面就是实战案例,一起来看一下。

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

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

    全局组件

    js

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

    局部组件demo:

    html

    <p 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>
      <p class="tabContent">
       <p 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"></p>
      </p>
      </p>

    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:'<p>{{content}}</p>'
           }
         },
         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形式存在:

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    readline怎样逐行读取并写入内容

    Vuex的mutations与actions使用详解

    以上就是vue全局注册和局部注册使用详解的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:使用 局部 注册
    上一篇:脚本加载后执行JS回调函数的方法 下一篇:angularjs中获取单选按钮的方法
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• 什么是消息队列?node中如何使用消息队列?• JavaScript的Symbol类型、隐藏属性及全局注册表详解• 18个常见angular面试题(附答案分析)• 浅析IDEA中如何开发Angular• 整理总结JavaScript常见的BOM操作
    1/1

    PHP中文网