这是一个使用 Vue3 组合式 API 和 TypeScript 的简单父子组件共享数据示例

父组件 Parent.vue:

<template>
<div>
<p>{{ msg }}</p>
<Child />
</div>
</template> <script lang="ts">
import { ref } from 'vue'
import Child from './Child.vue' export default {
components: { Child },
setup() {
const msg = ref('Hello from Parent!')
return { msg }
}
}
</script>

子组件 Child.vue:

<template>
<div>
<p>Hello, my name is {{ name }}</p>
</div>
</template> <script lang="ts">
import { ref } from 'vue' export default {
setup() {
const name = ref('John')
return { name }
}
}
</script>

父组件通过components属性注册子组件,并在模板中使用;子组件有自己的状态和数据逻辑。

两者之间的通信方式有:

  1. 父传子:通过子组件的props接收父组件传递的数据

修改父组件:

<template>
<div class="parent">
<p>{{ msg }}</p>
<Child :text="text"/>
</div>
</template> <script lang="ts">
import {ref} from 'vue'
import Child from '@/components/Child.vue' export default {
components: {Child},
setup() {
const msg = ref('Hello from Parent!')
const text = ref('some text')
return {msg, text}
}
}
</script> <style>
.parent {
background-color: #ffffff;
}
</style>

修改子组件:

<template>
<div class="child">
<p>Hello, my name is {{ name }}</p>
<p>{{ text }}</p>
</div>
</template> <script lang="ts">
import {ref} from 'vue' export default {
props: {
text: String
},
setup(props: { text: string }) {
console.log(props)
const name = ref('John')
return {name}
}
}
</script> <style>
.child {
background-color: #ffffff;
}
</style>

然后在子组件模板使用{{ text }}接收,也可以在setup中使用props

  1. 子传父:通过自定义事件@change,获取子组件传参

修改父组件:

<template>
<div class="parent">
<p>{{ msg }}</p>
<Child :text="text" @change="onChange"/>
<p>{{childText}}</p>
</div>
</template> <script lang="ts">
import {ref} from 'vue'
import Child from '@/components/Child.vue' export default {
components: {Child},
setup(props: any, {expose}: any) {
const msg = ref('Hello from Parent!')
const text = ref('some text')
const childText = ref("") const onChange = (text: string) => {
childText.value = text;
} return {msg, text, childText, onChange}
}
}
</script> <style>
.parent {
background-color: #ffffff;
}
</style>

修改子组件:

<template>
<div class="child">
<p>Hello, my name is {{ name }}</p>
<p>{{ text }}</p>
</div>
</template> <script lang="ts">
import {ref} from 'vue' export default {
props: {
text: String
},
emits: ['update'],
setup(props: { text: string }, {emit}: any) {
console.log(props);
const name = ref('John')
emit('change', 'emit change') return {name}
}
}
</script> <style>
.child {
background-color: #ffffff;
}
</style>

在子组件中调用emit('change', 'emit change')就可以触发父组件的方法。

ai问答:使用 Vue3 组合式API 和 TS 父子组件共享数据的更多相关文章

  1. vue3组合式API

    vue3组合式API 为什么要用组合式API,我们来看看它是如何解决vue2的局限性的 1.vue2的局限性 当组件内容越来越多,逻辑越来越复杂,可读性就会降低,并且难以维护. vue2组件采用配置式 ...

  2. vue3组合式API介绍

    为什么要使用Composition API? 根据官方的说法,vue3.0的变化包括性能上的改进.更小的 bundle 体积.对 TypeScript 更好的支持.用于处理大规模用例的全新 API,全 ...

  3. [Vue]浅谈Vue3组合式API带来的好处以及选项API的坏处

    前言 如果是经验不够多的同志在学习Vue的时候,在最开始会接触到Vue传统的方式(选项式API),后边会接触到Vue3的新方式 -- 组合式API.相信会有不少同志会陷入迷茫,因为我第一次听到新的名词 ...

  4. 解决WebStorm无法正确识别Vue3组合式API的问题

    1 问题描述 Vue3的组合式API无法在WebStorm中正确识别,表现为defineComponent等无法被识别: 2 尝试方案 猜想这种问题的原因是无法正确识别对应的Vue3库,笔者相信Web ...

  5. Vue3 组合式 API 中获取 DOM 节点的问题

    模板引用 Vue 提供了许多指令让我们可以直接操作组件的模板.但是在某些情况下,我们仍然需要访问底层 DOM 元素.在模板中添加一个特殊的属性ref就可以得到该元素. 访问模板引用 <scrip ...

  6. 第三十五篇:vue3,(组合式api的初步理解)

    好家伙, 来一波核心概念:数据劫持是响应式的核心 1.由set up开始 (1)vue3中的一个新的配置项,值为一个函数. (2)组件中所用的到的:数据,方法,计算属性均要配置在set up中. (3 ...

  7. Vue3笔记(二)了解组合式API的应用与方法

    一.组合式API(Composition API)的介绍 官方文档: https://v3.cn.vuejs.org/guide/composition-api-introduction.html 组 ...

  8. 一篇文章讲明白vue3的script setup,拥抱组合式API!

    引言 vue3除了Composition API是一个亮点之外,尤大大又给我们带来了一个全新的玩意 -- script setup,对于setup大家相信都不陌生,而对于script setup有些同 ...

  9. Vue3全局APi解析-源码学习

    本文章共5314字,预计阅读时间5-15分钟. 前言 不知不觉Vue-next的版本已经来到了3.1.2,最近对照着源码学习Vue3的全局Api,边学习边整理了下来,希望可以和大家一起进步. 我们以官 ...

  10. 纯小白入手 vue3.0 CLI - 2.5 - 了解组件的三维

    vue3.0 CLI 真小白一步一步入手全教程系列:https://www.cnblogs.com/ndos/category/1295752.html 我的 github 地址 - vue3.0St ...

随机推荐

  1. typescript开发vue项目二次封装的axios用return Promise.reject(error) 返回异常,提示[Vue warn]: Error in v-on handler (Promise/async)

    二次封装axios时刻意服务端模拟了延迟返回数据的场景,用return Promise.reject(error) 返回异常,报如下错误, [Vue warn]: Error in v-on hand ...

  2. Python:合并两个列表成为一个list

    如何合并两个列表,今天就来探讨一下: 方法一:最笨的方法实现 list1=[1,2,3]list2=[4,5,6]new_list=[]for item in list1: new_list.appe ...

  3. 后台运行&和nohup使用

    这里首先先介绍一下 ctrl+z bg fg jobs 命令 下面为了观察效果,test1.sh脚本不停的输出hello ctrl + z ,会使一个正在运行的进程挂起(暂停)到后台,而且执行jobs ...

  4. unlua

    安装 复制 Plugins 目录到你的UE工程根目录. 重新启动你的UE工程 注意点 新建工程后,必须重新拷贝插件,重新编译.不能从老项目中拷贝,会崩溃~ 加载c++类和蓝图类 -- c++类 loc ...

  5. 如何建设私有云原生 Serverless 平台

    随着云计算的普及,越来越多的企业开始将业务应用迁移到云上.然而,如何构建一套完整的云原生 Serverless 平台,依然是一个需要考虑的问题. Serverless的发展趋势 云计算行业从 IaaS ...

  6. Matlab笔记--Matlab概述(初登场)

    Matlab概述 安装MATLAB教程 可以参考这里:https://www.cnblogs.com/sixuwuxian/p/15858196.html Matlab的启动 右键图标,选择属性,可以 ...

  7. 使用nsis美化安装向导后,安装时实现浏览器自定义协议打开

    1. electron官方提供api,支持向注册表中写入协议,可通过浏览器打开 app.setAsDefaultProtocolClient('open-electron') 问题:1. 因为该方法时 ...

  8. 一次对pool的误用导致的.net频繁gc的诊断分析

    (最近有读者朋友表示,希望能加一些示意图来描述分析过程中用到的原理知识.好的,之后我会注意,谢谢这位读者) 背景 有位朋友找我,希望我能帮看一下他的一个service.从他的描述看,并没有资源方面的泄 ...

  9. 深入理解 python 虚拟机:pyc 文件结构

    深入理解 python 虚拟机:pyc 文件结构 在本篇文章当中主要给大家介绍一下 .py 文件在被编译之后对应的 pyc 文件结构,pyc 文件当中的一个核心内容就是 python 字节码. pyc ...

  10. 基于Admin.NET框架的前端的一些改进和代码生成处理(2)

    在上篇随笔<基于Admin.NET框架的前端的一些改进和代码生成处理(1)>中大致介绍了一些关于对Admin.NET框架的前端的改造工作,主要目的就是希望能够增加前端代码的简洁性和可读性, ...