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

【Vue3】3-3 : 组件之间是如何进行互相通信的

本书目录:点击进入

一、组件之间为什么要做通信

二、组件之间通信方式

2.1、父传子:由传递属性实现

stage 1:申明 (即定义)

stage 2:注册

stage 3:使用

【示例】:父组件将 title 和 count 传递给子组件 (普通数据 和 响应式数据的传递)

>  代码 

>  效果

2.2、子传父:由自定义事件实现 

stage 1:申明 (即 父组件:定义方法 + 子组件:调用方法)

stage 2:注册

stage 3:使用

 【示例】:子组件将 data 传递给父组件 

>  代码 

>  效果


一、组件之间为什么要做通信

  • 主要是为了让组件满足不同的需求

如:

  • 评分组件显示:由5颗星变成10颗星
  • 按钮组件显示:红色删除,比较危险

二、组件之间通信方式

vue中有4-5种,本节介绍最常见的 

  • 父子通信

2.1、父传子:由传递属性实现

stage 1:申明 (即定义)

stage 2:注册

stage 3:使用

【示例】:父组件将 title 和 count 传递给子组件 (普通数据 和 响应式数据的传递

  • 普通数据:title="hello world" ,无法响应式修改数据

  • 响应式数据 :count="count"

>  代码 
<body><div id="app"><my-head title="hello world" :count="count"></my-head></div><script>let app = Vue.createApp({data(){return {count: 10,title: "hello vue3"}},mounted(){setTimeout(()=>{this.title = "hello vue3";this.count = 20;}, 2000)}})app.component('MyHead', {props: {'count': {type: Number}},props: ['title', 'count'],template: `<header><div>{{ title }},{{ count }}</div><h2>logo</h2><ul><li>首页</li><li>视频</li><li>音乐</li></ul></header>`});let vm = app.mount('#app');</script>
</body>
>  效果

2.2、子传父:由自定义事件实现 

stage 1:申明 (即 父组件:定义方法 + 子组件:调用方法

stage 2:注册

stage 3:使用

 【示例】:子组件将 data 传递给父组件 

>  代码 
<body>
<div id="app"><div>{{message}}</div><my-head @custom-click="handleClick"></my-head></div><script>let app = Vue.createApp({data(){return {message: "app Data"}},methods: {handleClick(data){// console.log(data);this.message = data;}}})app.component('MyHead', {emits: ['custom-click'], template: `<header><h2>logo</h2><ul><li>首页</li><li>视频</li><li>音乐</li></ul></header>`,mounted(){setTimeout(()=>{this.$emit('custom-click', 'MyHead Data')}, 2000)}});let vm = app.mount('#app');</script>
</body>
>  效果

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

相关文章:

  • 网络端口映射和端口转发的区别和联系
  • VLSI超大规模集成电路设计复习
  • GCC 内联汇编
  • springboot整合websocket后启动报错:javax.websocket.server.ServerContainer not available
  • Vue面试之生命周期(上篇)
  • Gin 框架之用户密码加密
  • 【创作活动】ChatGPT 和文心一言哪个更好用?
  • 【linux】查看Debian应用程序图标对应的可执行命令
  • TortoiseSVN客户端如何安装配置并实现公网访问服务端提交文件到本地服务器
  • 【AUTOSAR】RTE 接口类型、应用场景差别及实例讲解
  • Qt应用开发(安卓篇)——Hello Qt On Android
  • 第十三讲_css 伸缩盒模型flex
  • 【C++干货铺】C++11常用新特性 | 列表初始化 | STL中的变化
  • k8s的对外服务---ingress
  • element-ui的el-upload组件实现上传拖拽排序图片顺序(sortablejs)
  • 【PS】PS设计图欣赏、学习、借鉴
  • 游戏云化好吗?游戏云化会带来什么?
  • 制造业企业数字化转型难点剖析及解决之法
  • golang 服务端遇到strict-origin-when-cross-origin,解决跨域整理
  • 分布式事务Seata实战-AT模式(注册中心为Eureka)
  • windows vscode jsoncpp cmake c++ 构建项目
  • 按照一定规则批量修改文件夹内文件的名称
  • Git项目分支管理规范
  • ycsb压测mongodb
  • 【zip密码】Zip压缩包删除密码方法,有哪些?
  • 代码随想录算法训练营day24 || 回溯法原理讲解,77.组合
  • RPA与通知机器人的完美结合
  • openssl3.2 - 官方demo学习 - signature - rsa_pss_direct.c
  • 高效批量剪辑技巧:一键按指定时长精准分割视频的方法,轻松制作视频
  • Android基础知识