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


Posted in Javascript onJune 04, 2018

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的实现

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 实现无干扰阴影效果 简单好用(附文件下载)
Dec 27 Javascript
Web开发之JavaScript
Mar 29 Javascript
javascript作用域容易记错的两个地方分析
Jun 22 Javascript
简介JavaScript中的getSeconds()方法的使用
Jun 10 Javascript
纯javascript实现自动发送邮件
Oct 21 Javascript
轻松掌握JavaScript中的Math object数学对象
May 26 Javascript
基于layer.js实现收货地址弹框选择然后返回相应的地址信息
May 26 Javascript
jquery在vue脚手架中的使用方式示例
Aug 29 jQuery
webpack的tree shaking的实现方法
Sep 18 Javascript
原生js实现html手机端城市列表索引选择城市
Jun 24 Javascript
vue配置多代理服务接口地址操作
Sep 08 Javascript
jQuery实现购物车全功能
Jan 11 jQuery
深入浅析JS中的严格模式
Jun 04 #Javascript
详解如何在你的Vue项目配置vux
Jun 04 #Javascript
详解vue-loader在项目中是如何配置的
Jun 04 #Javascript
vue.js打包之后可能会遇到的坑!
Jun 03 #Javascript
详解vue项目中如何引入全局sass/less变量、function、mixin
Jun 02 #Javascript
vue之将echart封装为组件
Jun 02 #Javascript
React学习笔记之高阶组件应用
Jun 02 #Javascript
You might like
php采用curl模仿登录人人网发布动态的方法
2014/11/07 PHP
简单了解将WordPress中的工具栏移到底部的小技巧
2015/12/31 PHP
PHP聚合式迭代器接口IteratorAggregate用法分析
2017/12/28 PHP
Jquery 扩展方法
2010/05/06 Javascript
jquery ajax,ashx,json的用法总结
2014/02/12 Javascript
JQEasy-ui在IE9以下版本中二次加载的问题分析及处理方法
2014/06/23 Javascript
jQuery源码分析之jQuery中的循环技巧详解
2014/09/06 Javascript
PHPExcel中的一些常用方法汇总
2015/01/23 Javascript
JS使用eval解析JSON的注意事项分析
2015/11/14 Javascript
java必学必会之static关键字
2015/12/03 Javascript
BootStrap中关于Select下拉框选择触发事件及扩展
2016/11/22 Javascript
详解angular2采用自定义指令(Directive)方式加载jquery插件
2017/02/09 Javascript
vue实现商城购物车功能
2017/11/27 Javascript
bootstrap下拉分页样式 带跳转页码
2018/12/29 Javascript
总结4个方面优化Vue项目
2019/02/11 Javascript
[00:20]TI9不朽观赛名额抽取
2019/08/05 DOTA
Python中os.path用法分析
2015/01/15 Python
python创建关联数组(字典)的方法
2015/05/04 Python
Python socket网络编程TCP/IP服务器与客户端通信
2017/01/05 Python
致Python初学者 Anaconda入门使用指南完整版
2018/04/05 Python
关于Django ForeignKey 反向查询中filter和_set的效率对比详解
2018/12/15 Python
python 格式化输出百分号的方法
2019/01/20 Python
基于OpenCV python3实现证件照换背景的方法
2019/03/22 Python
记录Python脚本的运行日志的方法
2019/06/05 Python
python3 selenium自动化测试 强大的CSS定位方法
2019/08/23 Python
使用python代码进行身份证号校验的实现示例
2019/11/21 Python
python 实现将list转成字符串,中间用空格隔开
2019/12/25 Python
150行python代码实现贪吃蛇游戏
2020/04/24 Python
html5使用canvas画三角形
2014/12/15 HTML / CSS
联想美国官方商城:Lenovo美国
2017/06/19 全球购物
幼儿园园长岗位职责
2013/11/26 职场文书
办公室主任竞聘演讲稿
2014/05/15 职场文书
不同意离婚代理词
2015/05/23 职场文书
基于Python编写简易版的天天跑酷游戏的示例代码
2022/03/23 Python
Apache Hudi数据布局黑科技降低一半查询时间
2022/03/31 Servers
Android基于Fresco实现圆角和圆形图片
2022/04/01 Java/Android