vue组件讲解(is属性的用法)

什么是组件?

在说之前我们先搞清楚什么是组件?这样对我们下边的学习是很有帮助的。 
组件(Component)是Vue.js最强大的功能之一。组件可以扩展HTML元素,封装可以重复使用的代码。在较高层次上,组件就是自定义元素,Vue.js的编辑器为它添加特殊功能。在有些情况下,组件也可以是原生元素的形式,以is特性进行扩展。

怎么使用组件?

说道这里,组件是什么,我们都有了清楚的了解,但是怎么使用呢? 
首先,我们要进行注册,才能进行使用

注册

之前我们也说过,可以通过new来创建一个VUE实例

new Vue ({
    ‘el‘ : ‘#element‘,
    //选项
})
  • 1
  • 2
  • 3
  • 4

这样,一个vue实例我们就创建成功了,这时候就要注册一个组件,我们可以通过Vue.component(tagName,options)。由于作用域的不同,组件也是分为全局组件和局部组件的,我们先来说全局组件。

Vue.component(‘my-component‘,{
    //选项
})
  • 1
  • 2
  • 3

一个全局组件就这样组册成功了,此后便可以在父实例的模块中以自定义元素<my-component></my-component>的形式进行使用。一定切记,要确保在初始化根实例之前注册了组件:

<div id=‘app‘>
    <my-component></my-component>
</div>
  • 1
  • 2
  • 3
//注册组件
Vue.component(‘my-component‘,{
    ‘template‘ : ‘<div>一个全局组件</div>‘
})
//创建根实例
new Vue({
    ‘el‘ : ‘#app‘,
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

以上渲染出来就是:

<div id=‘app‘>
    <div>一个全局组件</div>
</div>
  • 1
  • 2
  • 3

局部注册

在开发中,我们不必在全局注册每个组件。通过使用组件实例选项注册,可以使组件仅在另一个实例/组件的作用域可用,代码如下:

var Child = {
    ‘template‘ : ‘<div>一个组件</div>‘
}

new Vue({
    ‘el‘ : ‘#app‘,
    //...
    ‘component‘ : {
        ‘my-component‘ : Child
        //此时该模板只能在父实例中使用
    }
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

这种封装方式也可适用于其他可注册的Vue功能。如指令

DOM模板解析说明

当使用DOM作为模板时(例如,将el选项挂载到一个已知的元素上),你会受到HTML的一些限制,因为Vue只有在浏览器解析和标准化HTML后才能获取模板内容。尤其像这些元素<ul>,<ol>,<table>,<select>限制了能被它保过的元素,而一些像option这样的元素只能出现在某些其他元素的内部。 
在自定义组件中使用这些受限制的元素时会导致一些问题,例如:

<table>
    <my-row>...</my-row>
</table>
  • 1
  • 2
  • 3

自定义组件<my-row>被认为是无效的内容,因此在渲染的时候会出现导致错误。变通的方案是使用特殊的is属性:

<table>
    <tr is=‘my-row‘>...</tr>
</table>
  • 1
  • 2
  • 3

应当注意,如果我们使用下面来源之一的字符串模板,这些限制将不适用:

  • <script type=‘text/x-template‘>
  • JavaScript内联模板字符串
  • .Vue组件 
    因此,有必要的话请使用字符串模板

data必须是函数

通过Vue构造器传入的各种选项大多数都可以在组件里使用。data是个例外,它必须是函数。实际上,如果我们这样做:

Vue.component(‘my-component‘,{
    ‘template‘ : ‘<span>{{message}}</span>‘,
    ‘data‘ : {
        ‘message‘ : ‘hello‘
    }
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

那么Vue会停止,并在控制台发出警告,告诉你在组件中data必须是函数。理解这种规则存在的意义很有帮助,让我们假设用如下方式来避开Vue的警告:

<div id=‘app‘>
    <simple-counter></simple-counter>
    <simple-counter></simple-counter>
    <simple-counter></simple-counter>
</div>
  • 1
  • 2
  • 3
  • 4
  • 5
var data = {counter : 0}

Vue.component(‘simple-counter‘,{
    ‘template‘ : ‘<button v-on:click=‘counter += 1‘>{{counter}}</button>‘
    //技术上data是一个函数,所以Vue不会警告
    //但是我们返回给每个组件的实例调用了同一个data对象
    ‘data‘ : function (){
        return data
    }
})

new Vue({
    ‘el‘ : ‘#app‘
})
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

由于这三个组件共享一个data,因此增加一个counter会影响所有组件!很明显,这样做是不对的。我们可以通过为每个组件返回全新的data对象来解决这个问题,如下:

data : function (){
    return {
        counter : 0
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5

现在每个counter都有它自己内部的状态了。

构成组件

组件意味着协同工作,通常父子组件会是这样的关系:组件A在它的模板中使用了组件B。它们之间必然需要相互通信:父组件要给子组件传递数据,子组件需要将它内部发生的事情告知给父组件。然而,在一个良好定义的接口中尽可能将父子组件解耦是很重要的。这保证了每个组件可以在相对隔离的环境中书写和理解,也大幅度提高了组件的可维护性和可重用性。 
在Vue中,父子组件的关系可以总结为 props down, events up。父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送消息。看看它们是怎么工作的。如图: 

原文地址:https://www.cnblogs.com/chenhuichao/p/8607472.html

时间: 2024-11-29 11:09:07

vue组件讲解(is属性的用法)的相关文章

vue组件的inheritAttrs属性

vue官网对于inheritAttrs的属性解释:如果你不希望组件的根元素继承特性,你可以在组件的选项中设置 inheritAttrs: false. 可能不是很好理解,我们可以举个例子来验证一下. 父组件 parent-component.vue <template> <div class="parent"> <child-component aaa="1111"></child-component> </di

Vue中is属性的用法 可以动态切换组件

is 是组件的一个属性,用来展示组件的名称 is和component联用哈 <component :is="comName"> vue提供了component来展示对应的组件名称 compont是一个占位符,is这个属性,用来展示对应的组件名称 三个子组件 <template> <div> <h2>我是登录组件</h2> </div> </template> <template> <d

vue 组件属性props,特性驼峰命名,连接线使用

今天在学习vue的时候碰到了一个有趣的问题 是这样的,先来个话题引入,后面会用到 var myname={ 'first-name':'9', 'last-name':'l o n g' } console.log(myname.first-name); console.log(myname['first-name']); 打印出来是  NaN  9 解释下,之所以没有前面没有打印出来9,是因为程序走的时候,把我们认为的英文连接符当做减号看待,myname.first是undefined,nam

Vue组件基础用法

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

vue组件之间的通信以及如何在父组件中调用子组件的方法和属性

在Vue中组件实例之间的作用域是孤立的,以为不能直接在子组件上引用父组件的数据,同时父组件也不能直接使用子组件的数据 一.父组件利用props往子组件传输数据 父组件: <div> <child v-bind:my-message="parentMsg"></child>//注意传递参数时要用-代替驼峰命名,HTML不区分大小写 </div> 子组件: Vue.component('child', { // camelCase in Ja

vue组件中的样式属性:scoped,解决在父组件中无法修改子组件样式问题

Scoped CSS规范是Web组件产生不污染其他组件,也不被其他组件污染的CSS规范. vue组件中的style标签标有scoped属性时表明style里的css样式只适用于当前组件元素,它是通过使用PostCSS来改变以下内容实现的: <style scoped> .example { color: red; } </style> <template> <div class="example">hi</div> </

Vue (表单、斗篷、条件、循环指令,分隔符成员、计算属性成员、属性的监听、vue组件、子组件)

表单指令 <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8"> <title>表单指令</title> </head> <body> <div id="app"> <form action=""> <!--属性指令:v-model=

vue组件最佳实践

看了老外的一篇关于组件开发的建议(强烈建议阅读英文原版),感觉不错翻译一下加深理解. 这篇文章制定一个统一的规则来开发你的vue程序,以至于达到一下目的.1.让开发者和开发团队更容易发现一些事情.2.让你更好的利用你的IDE.3.让你更加容易的使用打包工具4.让你的代码更容易碎片化以达到复用的目的. 基于模块开发 用一些功能单一的小模块来组织你的应用 Why? 对于你自己和你团队的人来说较小的模块更容易看懂 维护 复用和调试. How? 每个组件应该保持单一 独立 可复用 可测试把你很大的组件拆

JS组件系列——又一款MVVM组件:Vue(二:构建自己的Vue组件)

阅读目录 一.为什么组件很重要 二.Vue里面的组件基础知识 1.组件的概念 2.组件原理 3.组件使用 三.封装自己的Component 1.使用Component封装bootstrapTable 2.封装select 3.查看其他Vue框架源码 四.总结 正文 前言:转眼距离上篇 JS组件系列--又一款MVVM组件:Vue(一:30分钟搞定前端增删改查) 已有好几个月了,今天打算将它捡起来,发现好久不用,Vue相关技术点都生疏不少.经过这几个月的时间,Vue的发展也是异常迅猛,不过这好像和博