五分钟带你了解vue组件

    当我们使用 vue 进行开发的时候,一定会学到一个概念,叫做组件。我们一般会将 Vue 组件定义在一个文件后缀名为 .vue 的文件中,这就叫做单文件组件 (简称 SFC)

    使用组件的概念的好处也很简单。

    首先,我们可以将一个很复杂的页面拆分成一个一个的组件,比如一个页面可以先简单的拆分成导航栏,菜单栏,核心内容部分,底部栏,我们可以单独的把这些部分拆分成各个组件,开发的时候可以在里面自定义这个模块所需要的内容和逻辑,这也符合模块化的思想。

    其次,对于定义的每一个单独的组件,我们可以进行复用,比如在一个购物网站里,查看商品列表的时候,其实每一个商品的展示信息都是一样的,我们只需要将其维护成一个独立的组件,然后重复进行渲染就可以了。

    接下来我们先简单的认识一下组件的基本结构和语法。(无特殊说明,以下代码皆使用 vue3 的语法)

一:组件结构

<script setup>
import { ref } from 'vue'
const count = ref(0)
</script><template><button @click="count++">{{ count }}</button>
</template><style scoped></style>

从上面的代码中可以看到 vue3 的文件结构可以分为三个部分

  • script:定义组件的逻辑部分,包括组件的属性,方法,生命周期钩子函数等。
  • template:定义组件的 HTML 模板部分,包含组件的结构和内容。
  • style:定义组件的 css 样式

上面代码的作用是定义了一个按钮,并为这个按钮添加点击事件,当触发点击事件之后会将 count 的值加 1,并将 count 的值在页面中进行渲染。

二:使用组件

这一小节中介绍下如何使用我们定义好的组件。

父组件 Father.vue

<script setup>
import Son from './Son.vue'
</script><template><p>hello vue</p><Son></Son><Son></Son><Son></Son>
</template><style scoped></style>

子组件 Son.vue

<script setup>
import { ref } from 'vue'
const count = ref(0)
</script><template><button @click="count++">{{ count }}</button>
</template><style scoped></style>

页面效果

可以看到我们只需要在父组件中使用 import 引入子组件,就可以在模板中直接使用,而且在同一个组件中可以多次使用。

而且细心的小伙伴可能还会发现,虽然我们的子组件中有一个 count 属性,但是渲染的三个子组件的 count 值都是不一样,这是由于每当我们使用一个组件的时候,就创建了一个新的实例,这三个实例的状态都是独立的。

至此,我们虽然已经掌握了组件的基本使用。但是由于我们发现了对于使用的每个子组件,虽然他们的结构是一样的,但是渲染出来的数据却是独立的,因此,如何让子组件去渲染父组件想要的数据,甚至父组件会希望子组件能够去渲染他想要结构和样式,这就需要学习我们的父子组件通信和插槽的知识了,我们留到下篇文章再讲。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/313165.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单片机的存储、堆栈与程序执行方式

一、单片机存储区域 如图所示位STM32F103ZET6的参数&#xff1a; 单片机的ROM&#xff08;内部FLASH&#xff09;&#xff1a;512KB&#xff0c;用来存放程序代码的空间。 单片机的RAM&#xff1a;64KB&#xff0c;一般都被分配为堆、栈、变量等的空间。 二、堆和栈的概念 …

填充点云孔洞(较大的洞)halcon算法

前言 很多时候,一些小洞可以通过平滑算法,或者三角化算法的参数调整,即可对较小的孔洞进行填充,但是较大的洞却很难通过上面的算法进行填充。 下面介绍一种填充孔洞的思路: 步骤一:对点云进行滤波处理,找到孔洞所在平面 本文为了更直观的进行讲解,去掉了去除噪声和…

大一c语言期末复习题

第16题&#xff1a; 答案&#xff1a; #include<stdio.h> void hello_world(void) {printf("Hello,world!\n"); } void three_hellos(void) {int i 0;for (i 0; i < 3; i) //调用3次函数{hello_world();} } int main() {three_hellos();return 0; } 知…

金融帝国实验室(Capitalism Lab)官方正版游戏『2024新年特卖优惠』

「金融帝国实验室」&#xff08;Capitalism Lab&#xff09;Enlight 官方正版游戏「2024新年特卖」 ■优惠时限&#xff1a;2024.01.01&#xff5e;01.31 ■游戏开发商&#xff1a;Enlight Software Ltd. 请您认准以下官方正版游戏购买链接&#xff1a;支持“支付宝&am…

Conv2Former:一种transformer风格的卷积特征提取方式

一、前言 昨天读到了一篇有意思的文章&#xff0c;文章提出通过利用卷积调制操作来简化self-attention。还证明了这种简单的方法可以更好地利用卷积层中嵌套的大核(≥7 7)。我们都知道ViTs推动了设计识别模型的发展&#xff0c;近几年使用的也相当的多&#xff0c;通常就是CN…

你逛过凌晨四点的校园吗?--大四毕业生的年终总结

前言&#xff1a; Hello大家好&#xff0c;我是Dream。 又是一年的年终总结&#xff0c;我也迎来了自己的毕业季&#xff0c;没错&#xff0c;我马上要毕业啦&#xff01;不知道大家是什么时候认识我的呢&#xff0c;又或者是第一次发现我~这一年&#xff0c;迎接过朝阳、拍下过…

Linux:apache优化(1)—— 长链接/保持连接

系统:CentOS 7.9 apache版本为&#xff1a;2.4.25 需要使用源码包进行安装才能够使用这些扩展模块 在使用这些扩展模块前要先下载zlib-devel 安装--enable-deflate选项需要的网页压缩传输的软件包 yum -y install zlib-devel 在配置编译安装时需要使用扩展配置 ./config…

使用ChatGLM3自定义工具实现大模型查询MySQL数据库

ChatGLM3-6B 采用了全新设计的 Prompt 格式&#xff0c;除正常的多轮对话外。同时原生支持工具调用&#xff08;Function Call&#xff09;、代码执行&#xff08;Code Interpreter&#xff09;和 Agent 任务等复杂场景。 什么是工具调用 大模型虽然强大&#xff0c;但是由于…

java struts2教务管理系统Myeclipse开发mysql数据库struts2结构java编程计算机网页项目

一、源码特点 java struts2 教务管理系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助 struts2 框架开发&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境 为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库…

【数据结构-单链表】(C语言版本)

今天分享的是数据结构有关单链表的操作和实践&#xff08;图解法&#xff0c;图变化更利于理解&#xff09; 记录宗旨&#x1f4dd;&#xff1a; 眼&#xff08;脑&#xff09;过千遍&#xff0c;不如手过一遍。 我们都知道单链表是一种常见的链表数据结构&#xff0c;由一系列…

泽攸科技PECVD设备助力开发新型石墨烯生物传感器

近日&#xff0c;松山湖材料实验室许智团队与清华大学符汪洋合作在纳米领域头部期刊《Small》上发表了一项引人注目的研究成果&#xff0c;题为“Ultrasensitive biochemical sensing platform enabled by directly grown graphene on insulator”&#xff08;硅晶圆上直接生长…

34--JDK8新特性

1. Java版本迭代概述 1.1 发布特点&#xff08;小步快跑&#xff0c;快速迭代&#xff09; 发行版本 发行时间 备注 Java 1.0 1996.01.23 Sun公司发布了Java的第一个开发工具包 Java 5.0 2004.09.30 ①版本号从1.4直接更新至5.0&#xff1b;②平台更名为JavaSE、JavaE…