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 相关文章推荐
javascript如何使用bind指定接收者
May 04 Javascript
HTML5使用DeviceOrientation实现摇一摇功能
Jun 05 Javascript
详细解读JavaScript的跨浏览器事件处理
Aug 12 Javascript
深入解析JavaScript的闭包机制
Oct 20 Javascript
阿里巴巴技术文章分享 Javascript继承机制的实现
Jan 14 Javascript
JS中数组重排序方法
Nov 11 Javascript
自带气泡提示的vue校验插件(vue-verify-pop)
Apr 07 Javascript
JavaScript输入分钟、秒倒计时技巧总结(附代码)
Aug 17 Javascript
简单介绍react redux的中间件的使用
Apr 06 Javascript
浅析Vue 中的 render 函数
Feb 28 Javascript
详解微信小程序动画Animation执行过程
Sep 23 Javascript
js实现弹窗猜数字游戏
Nov 26 Javascript
深入浅析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扩展ZF――Validate扩展
2008/01/10 PHP
为PHP初学者的8点有效建议
2010/11/20 PHP
PHP中3种生成XML文件方法的速度效率比较
2012/10/06 PHP
ThinkPHP上使用多说评论插件的方法
2014/10/31 PHP
php简单实现MVC
2015/02/05 PHP
php+mongodb判断坐标是否在指定多边形区域内的实例
2016/10/28 PHP
php中yii框架实例用法
2020/12/22 PHP
(JS实现)MapBar中坐标的加密和解密的脚本
2007/05/16 Javascript
JavaScript 全角转半角部分
2009/10/28 Javascript
jQuery结合Json提交数据到Webservice,并接收从Webservice返回的Json数据
2011/02/18 Javascript
jquery阻止冒泡事件使用模拟事件
2013/09/06 Javascript
JavaScript限定图片显示大小的方法
2015/03/11 Javascript
JS数组array元素的添加和删除方法代码实例
2015/06/01 Javascript
jquery的幻灯片图片切换效果代码分享
2015/09/07 Javascript
jquery特效 点击展示与隐藏全文
2015/12/09 Javascript
JS实现根据文件字节数返回文件大小的方法
2016/08/02 Javascript
jquery 点击元素后,滚动条滚动至该元素位置的方法
2016/08/05 Javascript
vue中使用gojs/jointjs的示例代码
2018/08/24 Javascript
基于vue实现微博三方登录流程解析
2020/11/04 Javascript
python批量提交沙箱问题实例
2014/10/08 Python
基于Django的python验证码(实例讲解)
2017/10/23 Python
python 连接各类主流数据库的实例代码
2018/01/30 Python
pandas系列之DataFrame 行列数据筛选实例
2018/04/12 Python
Flask web开发处理POST请求实现(登录案例)
2018/07/26 Python
Windows下python3.7安装教程
2018/07/31 Python
python使用递归的方式建立二叉树
2019/07/03 Python
Python线上环境使用日志的及配置文件
2019/07/28 Python
Html5如何唤起百度地图App的方法
2019/01/27 HTML / CSS
业务主管岗位职责
2013/11/20 职场文书
自我评价200字分享
2013/12/17 职场文书
美德好少年主要事迹
2014/01/29 职场文书
校园摄影活动策划方案
2014/02/05 职场文书
投资意向书范本
2014/04/01 职场文书
2014年城管工作总结
2014/11/20 职场文书
送给教师们,到底该如何写好教学反思?
2019/07/02 职场文书
导游词之西安骊山
2019/12/20 职场文书