版权声明:出处http://blog.csdn.net/qq20004604

 

目录(?)[+]

 

本篇资料来于官方文档:

http://cn.vuejs.org/guide/components.html

本文是在官方文档的基础上,更加细致的说明,代码更多更全。

简单来说,更适合新手阅读

 

(二十五)组件的定义

①组件的作用:

【1】扩展HTML元素,封装可重用的代码;

【2】组件是自定义元素,Vuejs的编译器可以为其添加特殊的功能;

【3】某些情况下,组件可以是原生HTML元素的形式,以is的方式扩展。

②写一个标准的组件:

分为以下几步:

【1】挂载组件的地方,需要是Vue实例所渲染的html元素,具体来说,比如上面的<div id=”app”></div>这样的html元素及他的子节点;

【2】定义一个组件,用

var 变量名 = Vue.extend({template:”这里是html的模板内容”})

这样的形式创建,例如:

  1. //定义一个组件
  2. var btn = Vue.extend({
  3. template: "<button>这是一个按钮</button>"
  4. })

【3】将定义的组件注册到Vue实例上,这会让指定标签,被组件的内容所替代。

如代码:

  1. //注册他到Vue实例上
  2. Vue.component("add-button", btn);

具体而言,每一个以下这样的标签(在Vue的根实例范围内的)

  1. <add-button></add-button>

会被

  1. <button>这是一个按钮</button>

所替代。

【4】以上方法是全局注册(每个Vue实例的add-button标签都会被我们定义的所替代);

解决办法是局部注册。

如代码:(这是是设置了template属性,也可以在没有这个属性的时候,在<div id=”app”></div>标签内放置<add-button></add-button>标签

  1. <div id="app">
  2. </div>
  3. <script>
  4. //定义一个组件
  5. var btn = Vue.extend({
  6. template: "<button>这是一个按钮</button>"
  7. })
  8. Vue.component("add-button", btn);
  9. //创建根实例,也就是说让Vue对这个根生效
  10. var vm = new Vue({
  11. el: '#app',
  12. template: "<add-button></add-button>"
  13. });
  14. </script>

③局部注册组件:

简单来说,只对这一个Vue实例生效,具体做法是,在注册那一步,跳过;

然后在声明Vue实例的时候,将添加到components这个属性中(他是一个对象,以KV形式放置)(注意,这个单词多一个s)

如代码:

  1. <div id="app">
  2. </div>
  3. <script>
  4. //定义一个组件
  5. var btn = Vue.extend({
  6. template: "<button>这是一个按钮</button>"
  7. })
  8. //创建根实例,也就是说让Vue对这个根生效
  9. var vm = new Vue({
  10. el: '#app',
  11. template: "<add-button></add-button>",
  12. components: {
  13. "add-button": btn
  14. }
  15. });
  16. </script>

注:

根据官方教程,这种方法(指局部注册),也适用于其他资源,比如指令过滤器过渡

④步骤简化:

【1】定义组件和注册组件结合起来一步完成:

  1. //定义一个组件
  2. Vue.component("add-button", {
  3. template: "<button>这是一个按钮</button>"
  4. });

【2】局部注册时,定义和注册一步完成:

  1. //创建根实例,也就是说让Vue对这个根生效
  2. var vm = new Vue({
  3. el: '#app',
  4. template: "<add-button></add-button>",
  5. components: {
  6. "add-button": {
  7. template: "<button>这是一个按钮</button>"
  8. }
  9. }
  10. });

⑤data属性

直接给组件添加data属性是不可以的(无效);

原因在于,假如这么干,那么组件的data属性有可能是一个对象,而这个对象也有可能是外部传入的(例如先声明一个对象,然后这个对象作为data的值),可能导致这个组件的所有副本,都共享一个对象(那个外部传入的),这显然是不对的。

因此,data属性应该是一个函数,然后有一个返回值,这个返回值作为data属性的值。

且这个返回值应该是一个全新的对象(即深度复制的,避免多个组件共享一个对象);

如代码:

  1. var vm = new Vue({
  2. el: '#app',
  3. template: "<add-button></add-button>",
  4. components: {
  5. "add-button": {
  6. template: "<button>这是一个按钮{{btn}}</button>",
  7. data: function () {
  8. return {btn: "123"};
  9. }
  10. }
  11. }
  12. });

另外,假如这样的话,btn的值是一样的(因为他们实际上还是共享了一个对象)

  1. <div id="app">
  2. </div>
  3. <div id="app2">
  4. </div>
  5. <script>
  6. var obj = {btn: "123"};
  7. var vm = new Vue({
  8. el: '#app',
  9. template: "<add-button></add-button>",
  10. components: {
  11. "add-button": {
  12. template: "<button>这是一个按钮{{btn}}</button>",
  13. data: function () {
  14. return obj;
  15. }
  16. }
  17. }
  18. });
  19. obj.btn = "456";
  20. var vm2 = new Vue({
  21. el: '#app2',
  22. template: "<add-button></add-button>",
  23. components: {
  24. "add-button": {
  25. template: "<button>这是一个按钮{{btn}}</button>",
  26. data: function () {
  27. return obj;
  28. }
  29. }
  30. }
  31. });
  32. </script>

注:

el属性用在Vue.extend()中时,也须是一个函数。

⑥is特性:

【1】按照官方教程,一些HTML元素对什么元素可以放在它之中是有限制的;

简单来说,如果我要在table标签内复用某个组件,这个组件展开后是tr标签,但是展开前不是,那么就无法正常运行(被放置在table标签内);

如代码(错误写法,会渲染错误):

  1. <div id="app">
  2. <table>
  3. <tr>
  4. <td>索引</td>
  5. <td>ID</td>
  6. <td>说明</td>
  7. </tr>
  8. <thetr v-for="i in items" v-bind:id="i" :index="$index"></thetr>
  9. </table>
  10. </div>
  11. <script>
  12. var vm = new Vue({
  13. el: '#app',
  14. data: {
  15. items: [1, 2, 3, 4]
  16. },
  17. methods: {
  18. toknowchildren: function () {   //切换组件显示
  19. console.log(this.$children);
  20. }
  21. },
  22. components: {
  23. thetr: { //第一个子组件
  24. template: "<tr>" +
  25. "<td>{{index}}</td>" +
  26. "<td>{{id}}</td>" +
  27. "<td>这里是子组件</td>" +
  28. "</tr>",
  29. props: ['id', 'index']
  30. }
  31. }
  32. });
  33. </script>

渲染结果如下:

  1. <div id="app">
  2. <tr><td>0</td><td>1</td><td>这里是子组件</td></tr>
  3. <tr><td>1</td><td>2</td><td>这里是子组件</td></tr>
  4. <tr><td>2</td><td>3</td><td>这里是子组件</td></tr>
  5. <tr><td>3</td><td>4</td><td>这里是子组件</td></tr>
  6. <table>
  7. <tbody>
  8. <tr>
  9. <td>索引</td>
  10. <td>ID</td>
  11. <td>说明</td>
  12. </tr>
  13. </tbody>
  14. </table>
  15. </div>

可以明显发现,内容没有被放在table之中。

正确写法如下:

  1. <div id="app">
  2. <button @click="toknowchildren">点击让子组件显示</button>
  3. <table>
  4. <tr>
  5. <td>索引</td>
  6. <td>ID</td>
  7. <td>说明</td>
  8. </tr>
  9. <tr is="thetr" v-for="i in items" v-bind:id="i" :index="$index"></tr>
  10. </table>
  11. </div>

Vuejs——(8)Vuejs组件的定义的更多相关文章

  1. vuejs 单文件组件.vue 文件

    vuejs 自定义了一种.vue文件,可以把html, css, js 写到一个文件中,从而实现了对一个组件的封装, 一个.vue 文件就是一个单独的组件.由于.vue文件是自定义的,浏览器不认识,所 ...

  2. Android:认识R类、findViewById方法查找组件、@string查找字符、@color查找颜色、@drawable查找图片、@dimen某个组件尺寸定义、项目引入资源国际化

    导入 之前都是断断续续的看了一些于如何使用android开发的文章.资料等,到目前位置很多基础的东西都不清楚,于是去学习了别人的课程,才了认识了R类.findViewById方法查找组件.项目引入资源 ...

  3. Vue组件的定义、注册和调用

    <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title>组 ...

  4. Vue.js 2.x:组件的定义和注册(详细的图文教程)

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 前言 什么是组件 组件: 组件的出现,就是为了拆分Vue实例的代码量的, ...

  5. vue里在自定义的组件上定义的事件

    事件分为原生事件和自定义事件. vue里在自定义的组件上定义的事件,都被认为是自定义事件,必须用$emit()来触发. 这也是子组件向父传值的原理. 如果想作为原生事件,需要在原生事件后面加上.nat ...

  6. Knockout.js组件系统的详解之(一) - 组件的定义和注册

    (Knockout版本:3.4.1 ) KO的组件主要从以下四个部分进行详细介绍: 1.组件的定义和注册 2.组件绑定 3.使用自定义元素 4.自定义组件加载器(高级) 目录结构 1.通过" ...

  7. vue教程3-03 vue组件,定义全局、局部组件,配合模板,动态组件

    vue教程3-03 vue组件,定义全局.局部组件,配合模板,动态组件 一.定义一个组件 定义一个组件: 1. 全局组件 var Aaa=Vue.extend({ template:'<h3&g ...

  8. Vue 数组封装和组件data定义为函数一些猜测

     数组封装 var vm={ list:[0,1] } var push=vm.list.push;//把数组原来的方法存起来 vm.list.push=function(arg){//重新定义数组的 ...

  9. vue学习—组件的定义注册

    组件的定义注册 效果: 方法一: <div id="box"> <v-header></v-header> <hr /> <b ...

随机推荐

  1. 深度学习原理与框架-CNN在文本分类的应用 1.tf.nn.embedding_lookup(根据索引数据从数据中取出数据) 2.saver.restore(加载sess参数)

    1. tf.nn.embedding_lookup(W, X) W的维度为[len(vocabulary_list), 128], X的维度为[?, 8],组合后的维度为[?, 8, 128] 代码说 ...

  2. cfile fopen fopen_s win10下打开文件失败

    vc程序在win10下面使用fopen 打开文件失败,在网上查 了下是因为UAC权限的问题如下: 由于windows vista win7 win8 win 10 添加了UAC权限,所以会导致 在系统 ...

  3. Django_Form验证(二),ajax验证

    还是一个简单的html提交页面,ajax提交就不需要form表单了: <p><input id="a" type="text" name=&q ...

  4. hbase--知识点总结2

    --用java操作hbase 1.配置jar包环境 创建hbase项目 --> 新建folder文件夹 --> 将hbase相关jar包全部导入到java项目之中 --> add b ...

  5. SpringMVC 重定向和请求转发(转载)

    本文系转载,原文地址:https://blog.csdn.net/m0_37450089/article/details/78703366   servlet的请求转发(forward)和重定向(se ...

  6. centos7源码安装heartbeat可能出现的错误以及解决办法

    问题:ipmilan_command.c: In function 'setup_ipmi_conn':ipmilan_command.c:283:2: error: 'sel_alloc_selec ...

  7. CentOS 性能监测命令

    1.实时监测命令(watch) -d 高亮显示变化 -n 间隔多久(s) 执行后面的command #每隔1秒显示空间使用情况并列出当前目录下的列表信息 EX:watch -d -n 1 'df -h ...

  8. AltiumDesigner印制导线的走向及形状

    印制导线的走向及形状.在PCB布线时,相邻层的走线方向成正交结构,应避免将不同的信号线在相邻走成同一方向,以减少不必要的层间窜扰.当PCB布线受到结构限制(如某种背板)难以避免出现平行布线时,特别是当 ...

  9. ExecuteNonQuery()

    ExecuteNonQuery():执行一个SQL语句,返回受影响的行数,这个方法主要用于执行对数据库执行增加.更新.删除操作,注意查询的时候不是调用这个方法.用于完成insert,delete,up ...

  10. IMU

    (1)用IMU来进行预测 读入一个10/20帧的数据集,通过IMU来初步预测出位姿以及显示其路径. Christian Forster, Luca Carlone, Frank Dellaert, D ...