当前位置: 首页 > news >正文

vue3中父组件与子组件关系的理解 ------类比java中的启动类,类,对象等概念来解释一下

编程时的一点感受:    感觉子组件本身像是java的一个类,父组件像是启动类,父组件里引用子组件像是创建子组件的对象

查找资料后,发现确实如此,在很多方面,Vue 组件确实可以与面向对象编程中的类进行类比。

子组件(Vue 组件)类似于 Java 中的类

  • 属性 (Props): 在 Vue 组件中,props 类似于 Java 类中的属性或字段。它们是从父组件传递到子组件的数据。

    • Java 类中的属性:private int id;
    • Vue 组件中的 propsconst props = defineProps<{ id: number }>();
  • 方法 (Methods): 在 Vue 组件中,你可以定义方法来处理逻辑,这类似于 Java 类中的方法。

    • Java 类中的方法:public void someMethod() { ... }
    • Vue 组件中的方法:const someMethod = () => { ... };
  • 生命周期钩子 (Lifecycle Hooks): Vue 组件有生命周期钩子(如 mounted, beforeUnmount 等),这些类似于 Java 类中的构造函数和析构函数。

    • Java 类中的构造函数:public MyClass() { ... }
    • Vue 组件中的生命周期钩子:onMounted(() => { ... });
  • 模板 (Template): Vue 组件中的模板部分定义了组件的视图,这类似于 Java 中的 UI 渲染逻辑(例如在 Swing 或 JavaFX 中)。

父组件类似于启动类

  • 创建子组件的对象: 在 Vue 中,父组件通过 <child-component :prop="value" /> 的方式引用子组件,并传递必要的属性。这类似于在 Java 中创建一个类的实例并传递参数给构造函数。

    • Java 中创建对象:MyClass obj = new MyClass(someValue);
    • Vue 中引用子组件:<ChildComponent :someProp="someValue" />
  • 管理多个子组件: 父组件可以包含和管理多个子组件,这类似于 Java 中的一个主类管理多个其他类的实例。

    • Java 中的主类:public class Main { public static void main(String[] args) { ... } }
    • Vue 中的父组件:<template><ChildComponent1 /><ChildComponent2 /></template>

示例

假设你有一个简单的 Vue 应用,其中有一个父组件 ParentComponent 和一个子组件 ChildComponent

子组件 (ChildComponent.vue)
<script setup>
import { defineProps } from 'vue';const props = defineProps<{id: number;name: string;
}>();const greet = () => {console.log(`Hello, ${props.name}! Your ID is ${props.id}.`);
};
</script><template><div><h1>{{ name }}</h1><p>ID: {{ id }}</p><button @click="greet">Greet</button></div>
</template>
父组件 (ParentComponent.vue)
<template><div><h1>Parent Component</h1><ChildComponent :id="1" :name="John Doe" /><ChildComponent :id="2" :name="Jane Smith" /></div>
</template><script setup>
import ChildComponent from './ChildComponent.vue';
</script>

在这个例子中:

  • ChildComponent 定义了两个必需的属性 id 和 name,以及一个方法 greet
  • ParentComponent 引用了 ChildComponent 两次,并为每个引用传递了不同的 id 和 name 属性。

总结

        这种结构使得 Vue 组件化开发具有高度的模块化和可复用性,类似于面向对象编程中的类和对象的关系。

http://www.lryc.cn/news/458543.html

相关文章:

  • Java设计模式——装饰模式
  • 【TouchSocket 和 client.GetStream 区别】
  • 怎么利用商品详情API接口实现数据获取与应用?
  • 【AGC005D】~K Perm Counting(计数抽象成图)
  • 【React】setState (useState) 是怎么记住上一个状态值的?
  • Vue3 使用CryptoJS加密
  • Feign的使用
  • 前端反接保护:实用方案解析与探讨
  • 【C++】第五节:内存管理
  • 【Java SE】方法 和 递归 的应用
  • JVS低代码轻应用是什么?是如何拼装的?这篇文章讲的非常详细
  • K210(openMV)与STM32 通信教程
  • 【HarmonyOS】HMRouter使用详解(三)生命周期
  • Docker 教程三 (Ubuntu Docker安装)
  • Redis:持久化
  • 精准监控,高效运营 —— 商品信息实时分析为商家带来新机遇
  • Nginx应用配置实战
  • html实现倒计时
  • HTMLCSS练习
  • LeetCode讲解篇之377. 组合总和 Ⅳ
  • Midjourney中文版:创意无限,艺术之旅由此启程
  • 安装R和RStudio:开始你的数据分析之旅
  • 如何使用python连接数据库?
  • 停车位识别数据集 图片数量12416张YOLO,xml和txt标签都有; 2类类别:space-empty,space-occupied;
  • MySQL 创建子账号
  • 代码随想录 106. 岛屿的周长
  • 阿里云融合认证中的App端一键登录能力
  • 基于YOLO11/v10/v8/v5深度学习的安检X光危险品检测与识别系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】
  • vue-插槽作用域实用场景
  • Prometheus+Grafana 监控 K8S Ingress-Ningx Controller