Vue中父组件与子组件之间的通信

简介: Vue中父组件与子组件之间的通信

prop 父组件向子组件传递数据, 单向绑定

$refs 父组件调用子组件里的属性和方法

$emit 子组件向父组件传递消息

新建项目

$ vue create demo
$ cd demo
$ npm run serve

1、父组件引用子组件

components/Child.vue

<template>

<h2>子组件</h2>
</template>

App.vue

<template>
<div id="app">
<h2>父组件</h2>

<!-- 3、使用子组件 -->
<Child></Child>

</div>
</template>

<script>
// 1、导入子组件
import Child from "@/components/Child.vue";

export default {
name: "app",

// 2、注册组件
components: {
Child // 键名与变量名相同, 等价于 Child: Child
}
};
</script>

2、父组件给子组件传值

components/Child.vue

<template>
<div>
<h2>子组件</h2>
<p>{ {message}}</p>
</div>
</template>

<script>
export default {
name: "child",

// 子组件属性,用于接收父组件数据, props是单向绑定
props:[
"message"
]
}
</script>

App.vue

<template>
<div id="app">
<h2>父组件</h2>

<!-- 父组件通过属性给子组件传值 -->

<!-- 静态绑定-->
<Child message="hello"></Child>

<!-- 动态绑定 -->
<Child v-bind:message="message"></Child>

</div>
</template>

<script>
import Child from "@/components/Child.vue";

export default {
name: "app",

data() {
return {
message: "hello child"
};
},

components: {
Child
}
};
</script>

3、父组件操作子组件数据,方法

components/Child.vue

<template>
<div>
<h2>子组件</h2>

<p>{ {message}}</p>

</div>
</template>

<script>
export default {
name: "child",

// 子组件属性
data(){
return {
message: "",
}
},

// 子组件方法
methods:{
setMessage(msg){
this.message = msg;
}
}
}
</script>

App.vue

<template>
<div id="app">
<h2>父组件</h2>

<!-- 注册子组件引用信息 -->
<Child ref="child"></Child>

<button @click="setChildMessage">修改子组件数据</button>

<button @click="callChildMessage">调用子组件方法</button>

</div>
</template>

<script>
import Child from "@/components/Child.vue";

export default {
name: "app",

components: {
Child
},

methods: {
setChildMessage() {
this.$refs.child.message = "设置子组件属性"
},

callChildMessage(){
this.$refs.child.setMessage("调用子组件方法");
}
}
};
</script>

$refs 不是响应式的,只在组件渲染完成后才填充

4、子组件给父组件传值

components/Child.vue

<template>
<div>
<h2>子组件</h2>

<!-- 点击按钮将会给父组件传值 -->
<button @click="clickButton">子组件按钮</button>

</div>
</template>

<script>
export default {
name: "child",

methods: {
clickButton() {
// 向父组件发送信号 vm.$emit(event, args)
this.$emit("clickButton", "子组件的按钮被点击");
}
}
};
</script>

App.vue

<template>
<div id="app">
<h2>父组件</h2>

<!-- 处理子组件的按钮点击事件 -->
<Child @clickButton="childClickButton"></Child>

</div>
</template>

<script>
import Child from "@/components/Child.vue";

export default {
name: "app",

components: {
Child
},

methods: {
// 接收处理子组件传递过来的数据
childClickButton(message) {
console.log(message);
}
}
};
</script>

参考:

  1. vue之父子组件间通信实例讲解(props、$ref</code>、<code style="font-family:monospace;font-size:inherit;background-color:rgba( 0 , 0 , 0 , 0.06 );padding:0px 2px;border:1px solid rgba( 0 , 0 , 0 , 0.08 );border-radius:2px;line-height:inherit;text-indent:0px">$emit)
  2. 【vue组件之间互相传值:父传子,子传父】
            </div>
目录
相关文章
|
存储 SQL 关系型数据库
创建并配置RDS实例
在阿里云上创建RDS实例涉及登录控制台、进入RDS管理页面、创建实例、选择数据库引擎和版本、配置实例规格与存储、设定网络与安全组、设置实例信息、确认订单并支付,最后初始化数据库。操作步骤可能因界面更新或数据库引擎不同略有差异。
569 1
|
11月前
|
机器学习/深度学习 人工智能 算法
AI在医疗:深度学习在医学影像诊断中的最新进展
【10月更文挑战第27天】本文探讨了深度学习技术在医学影像诊断中的最新进展,特别是在卷积神经网络(CNN)的应用。文章介绍了深度学习在识别肿瘤、病变等方面的优势,并提供了一个简单的Python代码示例,展示如何准备医学影像数据集。同时强调了数据隐私和伦理的重要性,展望了AI在医疗领域的未来前景。
471 2
|
安全 Cloud Native 算法
携手中科海光,龙蜥社区正式上线首个 CSV 机密容器解决方案
龙蜥 8.4已经正式支持基于海光 CSV 技术的机密容器,实现了容器从镜像下载到运行整个生命周期的安全性,是社区首个机密容器完整解决方案。
携手中科海光,龙蜥社区正式上线首个 CSV 机密容器解决方案
|
SQL 存储 JavaScript
会议OA系统会议管理模块开发思路(layui搭建)
会议OA系统会议管理模块开发思路(layui搭建)
196 0
|
存储 中间件 数据库
koa处理上传图片
koa处理上传图片
|
运维 Kubernetes 负载均衡
从概念、部署到优化,Kubernetes Ingress 网关的落地实践|学习笔记(一)
快速学习从概念、部署到优化,Kubernetes Ingress 网关的落地实践
成功解决ModuleNotFoundError: No module named 'dataset'
成功解决ModuleNotFoundError: No module named 'dataset'
|
Web App开发 移动开发 HTML5
告别div,可以代替div的几个标签
几个最常用的用来代替DIV的HTML5元素 虽说html5中大多数功能性的元素如等还得不到当前主流浏览器的支持(主要就是指IE浏览器了),但至少那些个与布局相关的元素同html5.js结合起来时我们是可以放心使用的,比如,,,,,,这几个最常用的元素。
1234 0
|
5天前
|
弹性计算 人工智能 安全
云上十五年——「弹性计算十五周年」系列客户故事(第二期)
阿里云弹性计算十五年深耕,以第九代ECS g9i实例引领算力革新。携手海尔三翼鸟、小鹏汽车、微帧科技等企业,实现性能跃升与成本优化,赋能AI、物联网、智能驾驶等前沿场景,共绘云端增长新图景。