Vue父子组建的简单通信之控制开关Switch的实现

作者:731947523 时间:2024-06-05 09:16:25 

Vue在目前是很好的框架,第一次使用Vue开发项目,刚开始的时候在一个控制开关的组件都花费了很久的时间,问题解决了,把自己的一些小问题给记录下来,方便以后看及帮助像我这样的初级萌新解决遇到的相同问题。

问题: 父组件传入值到子组件,子组件修改之后怎样传回到父组件 

父组件:内部首先要有三步

1、父组件中引用子组件

2、父组件中注册子组件

3、在子组件上绑定传值

父组件


<template>
<div class="hello">  
<ul>  
<li @click="changeFlag">点击开关----------------父组件默认为{{flag}}</li>  
</ul>  
<v-child :childFlag='flag' @parentChangeFlag='parentChangeFlag'></v-child>
//第三部
</div>
</template>
<script>
import child from '子组件地址' //第一步
data(){
 return{
   flag:false  }},
components:{
  'v-child': child  //第二步
}
</script>

在第三步骤里,绑定了一个childFlag传给子组件,其值为flag

子组件


< template >
<div class = "hello" >
<ul >
<li@click = "parentChangeFlag" > 显示 {
 {
   childFlag
 }
}---子元素: {
 {
   flag2
 }
}
< /li>  
<li @click="parentChangeFlag" v-show="childFlag"><img src="./images / ios_switch_off.png " alt="">
</li>  
<li @click="parentChangeFlag " v-show=" ! childFlag "><img src=". / images / ios_switch_on.png " alt=""></li>  
</ul>
</div>
</template>
< script > export
default {
   props:
   {
     childFlag:
     {
       type:
       Boolean,
     default:
       true
     }
   },
   data() {
     return {
       flag2: this.childFlag
     };
   },
   watch: {
     childFlag(flag2) {
       this.flag2 = this.childFla
     }
   },methods: { // 子组件传值给父组件  parentChangeFlag(){   this.flag2 = !this.flag2   this.$emit('parentChangeFlag',this.flag2)  } }};</script>

在父组件里,传了一个childFlag下来,我们要在子组件里去接收,方式用props,具体的可以看官方文档, 创建接收之后呢,我们需要把传进来的值绑定给我们子组件的data值即(flag2),完成这一步的话,我们就完成了父组件往子组件进行传值。

上面只是完成了父传子,下面讲述怎么子传父

子组件所需做的事情:

首先,我们需要在子组件里进行改变其状态值,这样我们就创建了一个parentChangeFlag点击事件,进而改变当前的子元素的(flag2)值;

其次,改变完当前的值,我们就要把子元素的状态值给传回父组件,这样就用到了$emit方法,this.$emit('function',Value);   function指父组件里监听子元素点击事件的函数;Value就代表你需要传回父元素的值。

父组件所需做的事情:

在父组件中,创建一个监听子元素改变data值的函数(即@parentChangeFlag='parentChangeFlag')


methods: {
 changeFlag() {
   //父组建点击改变元素传值给子组件  
   this.flag = !this.flag
 },
 parentChangeFlag: function(flag2) {
   //父组件监听子组件点击的函数 flag2为子组件传进来的值,把值赋给当前元素,就实现了父子之间的通信  
   console.log(flag2) this.flag = flag2
 }
}

当你完成父子组件各自所需要的工作时候,就恭喜你了,已经完成了Switch的效果,效果图如下

Vue父子组建的简单通信之控制开关Switch的实现

来源:https://juejin.im/post/5b0fd1796fb9a00a0634cf13

标签:Vue,父子,通信,控制开关,Switch
0
投稿

猜你喜欢

  • pyinstaller将python程序打包为可执行文件

    2022-06-05 17:11:35
  • 微信小程序实现登陆注册滑块验证

    2023-08-24 17:36:26
  • Python和php通信乱码问题解决方法

    2023-03-04 14:50:43
  • Python利用reportlab实现制作pdf报告

    2023-10-25 05:26:36
  • Vue element-ui表格内嵌进度条功能实现方法

    2024-05-28 15:51:59
  • python利用tkinter实现图片格式转换的示例

    2023-10-10 05:10:22
  • jQuery Ajax File Upload实例源码

    2024-04-09 19:48:58
  • python基础教程项目五之虚拟茶话会

    2022-10-25 02:08:47
  • 分享十个Python超级好用提高工作效率的自动化脚本

    2021-06-26 17:17:16
  • python 与服务器的共享文件夹交互方法

    2021-02-10 14:29:02
  • ASP开发中有用的函数(function)集合(1)

    2008-10-14 17:10:00
  • python操作MySQL 模拟简单银行转账操作

    2024-01-17 19:15:47
  • python列表与列表算法详解

    2022-09-20 20:36:51
  • 使用 Python 实现简单的 switch/case 语句的方法

    2021-02-02 09:10:16
  • 深入理解r2dbc在mysql中的使用

    2024-01-26 20:14:10
  • 原生JS中应该禁止出现的写法

    2024-04-10 11:00:49
  • VUE写一个简单的表格实例

    2023-07-02 16:56:30
  • python具名元组(namedtuple)的具体使用

    2021-08-02 18:10:38
  • PHP实现对图片的反色处理功能【测试可用】

    2023-11-03 19:41:28
  • tensorflow ckpt模型和pb模型获取节点名称,及ckpt转pb模型实例

    2021-05-23 10:22:53
  • asp之家 网络编程 m.aspxhome.com