组件

简介: 组件

组件

什么是组件

组件是可复用的 Vue 实例,说白了就是一组可以重复使用的模板,跟 JSTL 的自定义标签、 Thymeleaf 的 th:fragment 等框架有着异曲同工之妙。通常一个应用会以一棵嵌套的组件树的形式 来组织:

例如,你可能会有页头、侧边栏、内容区等组件,每个组件又包含了其它的像导航链接、博文之类的组 件。

第一个 Vue 组件

注意:在实际开发中,我们并不会用以下方式开发组件,以下方法只是为了让大家理解什么是组件。

使用 Vue.component() 方法注册组件:

06-vue-component.html

<body>

   <divid="app">

       <ul>

           <!-- 有点类似自定义标签 -->

           <my-component-li></my-component-li>

       </ul>

   </div>

   <scriptsrc="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js">

   </script>

   <script>

   // 先注册组件

   Vue.component('my-component-li', {

       template: '<li>Hello li</li>'

   });

   // 再实例化 Vue

   varvm=newVue({

       el: '#app'

   });

   </script>

</body>

说明:

  • Vue.component()注册组件
  • my-component-li:自定义组件的名字
  • template组件的模板(组件中的内容)

使用 props 属性传递参数

像上面那样用组件没有任何意义,所以我们是需要传递参数到组件的,此时就需要使用 props 属性 了

注意:默认规则下 props 属性里的值不能为大写:

06-vue-component-2.html

<body>

   <divid="app">

       <ul>

           <my-component-liv-for="item in items"v-bind:i="item">

                                           <!--将循环变量item绑定到组件中的变量i-->

           </my-component-li>

       </ul>

   </div>

   <scriptsrc="https://cdn.jsdelivr.net/npm/vue@2.5.21/dist/vue.js">

   </script>

   <script>

       // 先注册组件('组件名',{对象})

       Vue.component('my-component-li', {

           props: ['i'], // 为组件声明一个属性i

           template: '<li>Hello {{i}}</li>'

           // 因为vm和Vue都是对象,对象之间的属性无法互相传递

           // 所以这里用了绑定的特殊方法,template中才能拿到data中的值

       });

       // 再实例化 Vue

       varvm=newVue({

           el: '#app',

           data: {

               items: ["张三", "李四", "王五"]

           }

       });

   </script>

</body>

说明:

  • v-for="item in items" :遍历 Vue 实例中定义的名为 items 的数组,并创建同等数 量的组件;
  • v-bind:item="item" :将遍历的 item 项绑定到组件中 props 定义的名为 item 属 性上;
  • = 号左边的 item 为 props 定义的属性名,右边的为 item in items 中遍历的 item 项的值;

计算属性

相关文章
|
存储 运维 Oracle
国产数据库:目前最火的五款国产数据介绍
随着互联网的高速发展,目前数据的存储越来越多,传统的数据库逐渐不能满足人们对海量数据、高效查询的需求,国产的数据库如雨后春笋一样,一个个冒了出来来解决我们高速科技发展的数据库瓶颈,今天就给大家聊一聊目前最火的五款国产数据库,大家一起来交流一下。
国产数据库:目前最火的五款国产数据介绍
|
Java 编译器 测试技术
Kotlin31 协程如何与 Java 进行混编?
Kotlin31 协程如何与 Java 进行混编?
291 2
Kotlin31 协程如何与 Java 进行混编?
|
存储 SQL 数据挖掘
TDengine 流计算与窗口机制的深度解析:揭示计数窗口的关键作用
在 TDengine 3.2.3.0 版本中,我们针对流式计算新增了计数窗口,进一步优化了流式数据处理的能力。本文将为大家解读流式计算与几大窗口的关系,并针对新增的计数窗口进行详细的介绍,帮助大家进一步了解 TDengine 流式计算,以便更好地进行应用。
231 1
|
存储 程序员 开发者
Python 编程入门:从零基础到编写实用脚本
【9月更文挑战第15天】本文是一篇面向初学者的Python编程入门指南,通过浅显易懂的语言和实际的代码示例,引导读者逐步掌握Python的基本概念、语法规则以及如何运用Python解决实际问题。文章不仅介绍了Python的基础知识点,还通过实例演示了如何将这些知识应用于日常编程任务中,帮助读者快速上手并能够独立编写简单的Python脚本。
|
弹性计算 Java Linux
部署单点WordPress网站
在特定场景下编写模板的流程比较固定,本篇文章以《部署单点 WordPress 博客平台》为例,讲述如何完成一个部署成功率高、适配场景广的模板。大多数在 ECS 上部署应用的模板都可以参考此教程来编写。
27781 7
|
存储 缓存 安全
掌握Linux字符设备驱动程序的核心要点
掌握Linux字符设备驱动程序的核心要点
349 0
|
机器学习/深度学习
leetcode-52:N皇后 II
leetcode-52:N皇后 II
115 0
|
SQL 新零售 固态存储
基于Python GUI开发的快递管理系统
基于Python GUI开发的快递管理系统
429 0
基于Python GUI开发的快递管理系统
|
存储 算法 JavaScript
介绍Diff算法的概念
一、Diff算法tree diff 二、Diff算法 component diff 三、Diff算法element diff
介绍Diff算法的概念

热门文章

最新文章