vue 组件 全局注册和局部注册

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

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

全局组件

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

时间: 2024-11-06 11:41:32

vue 组件 全局注册和局部注册的相关文章

vue 组件 全局注册与局部注册的方法

全局注册 html部分 <div id="e1"><name1></name1></div> script部分 <script type="text/javascript"> Vue.component('name1', { template: '<div>我是效果</div>'})   //定义全局模板        例如 Vue.component(tagName, option

Vue组件全局/局部注册

全局注册 main.js中创建 Vue.component('button-counter', { data: function () { return { count: 0 } }, template: '<button v-on:click="count++">You clicked me {{ count }} times.</button>' }) 使用 <div id="components-demo"> <but

vue的全局方法和局部方法

var infiniteScroll = require('vue-infinite-scroll') 等价写法 import infiniteScroll from 'vue-infinite-scroll' Vue.use(infiniteScroll) //全局方法 var infiniteScroll = require('vue-infinite-scroll'); new Vue({ directives: {infiniteScroll} //局部方法(使用) })

vue.js 组件-全局组件和局部组件

这两天学习了Vue.js 感觉组件这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记. 首先Vue组件的使用有3个步骤,创建组件构造器,注册组件,使用组件3个方面. 代码演示如下: <!DOCTYPE html> <html> <body> <div id="app"> <!-- 3. #app是Vue实例挂载的元素,应该在挂载元素范围内使用组件--> <my-component></my-compo

VUE的双向绑定及局部组件的使用

vue的双向绑定,使用v-model,v-model只能使用在input  textare    select中 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>Title</title> <meta name="viewport" content="width=

Vue组件基础用法

前面的话 组件(Component)是Vue.js最强大的功能之一.组件可以扩展HTML元素,封装可重用的代码.根据项目需求,抽象出一些组件,每个组件里包含了展现.功能和样式.每个页面,根据自己所需,使用不同的组件来拼接页面.这种开发模式使前端页面易于扩展,且灵活性高,而且组件之间也实现了解耦.本文将详细介绍Vue组件基础用法 概述 组件是一个自定义元素或称为一个模块,包括所需的模板.逻辑和样式.在HTML模板中,组件以一个自定义标签的形式存在,起到占位符的功能.通过Vue.js的声明式渲染后,

vue组件详解(一)——组件与复用

一.什么是组件 组件 (Component) 是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码. 二.组件用法 组件需要注册后才可以使用,注册有全局注册和局部注册两种方式. 2.1 全局注册后,任何V ue 实例都可以使用.如: <div id="app1"> <my-component></my-component> </div> Vue.component('my-component',{ templ

Vue组件基础

gitHub地址:https://github.com/huangpna/vue_learn里面的lesson06 一 vue组件基本实例 举个例子: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>app1</title> </head> <body> <div id=&q

Vue组件 props

组件是Vue最强大的功能之一:组件化编程,允许我们使用小型,独立,通用的可复用型组件构建大型应用:任何页面都可以抽象为组件树: <!-- 组件需要注册后才能使用. 注册有全局注册和局部注册两种方式 全局注册: 全局: 局部注册: 局部: 注册后的组件只是在该作用域下有效 父组件正向的向子组件传递数据和参数 用 props props的值 可以是两种 1,字符串数组 props:['message'] 2,对象 props: {} props中的数据来自父元素.data中的数据来自组件自己的数据.