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函数setTimeout延迟执行的简单介绍
Jul 17 Javascript
jquery select 设置默认选中的示例代码
Feb 07 Javascript
选择复选框按钮置灰否则按钮可用
May 22 Javascript
基于JavaScript实现鼠标箭头移动图片跟着移动
Aug 30 Javascript
JavaScript中关于for循环删除数组元素内容时出现的问题
Nov 21 Javascript
JS出现失效的情况总结
Jan 20 Javascript
canvas实现探照灯效果
Feb 07 Javascript
详解JavaScript数组过滤相同元素的5种方法
May 23 Javascript
分析JavaScript数组操作难点
Dec 18 Javascript
js中innerText/textContent和innerHTML与target和currentTarget的区别
Jan 21 Javascript
微信小程序如何调用新闻接口实现列表循环
Jul 02 Javascript
vue使用i18n实现国际化的方法详解
Sep 05 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验证码类
2016/05/15 PHP
javascript判断单选框或复选框是否选中方法集锦
2007/04/04 Javascript
JQuery 1.4 中的Ajax问题
2010/01/23 Javascript
GWT中复制到剪贴板 js+flash实现复制 兼容性比较好
2010/03/07 Javascript
JQuery切换显示的效果实例代码
2013/02/27 Javascript
解读JavaScript中 For, While与递归的用法
2013/05/07 Javascript
jQuery 文本框得失焦点的简单实例
2014/02/19 Javascript
jQuery中get()方法用法实例
2014/12/27 Javascript
javascript实现图片自动和可控的轮播切换特效
2015/04/13 Javascript
ajax+jQuery实现级联显示地址的方法
2015/05/06 Javascript
jQuery实现弹出带遮罩层的居中浮动窗口效果
2016/09/12 Javascript
微信js-sdk地理位置接口用法示例
2016/10/12 Javascript
js中string和number类型互转换技巧(分享)
2016/11/28 Javascript
详解Javascript数据类型的转换规则
2016/12/12 Javascript
javascript操作cookie
2017/01/17 Javascript
Angularjs中数据绑定的实例详解
2017/08/25 Javascript
angularjs使用div模拟textarea文本框的方法
2018/10/02 Javascript
JS使用iView的Dropdown实现一个右键菜单
2019/05/06 Javascript
jquery插件开发模式实例详解
2019/07/20 jQuery
javascript自定义日期比较函数用法示例
2019/07/22 Javascript
vue使用高德地图点击下钻上浮效果的实现思路
2019/10/12 Javascript
python批量同步web服务器代码核心程序
2014/09/01 Python
python yield关键词案例测试
2019/10/15 Python
python快速排序的实现及运行时间比较
2019/11/22 Python
双向RNN:bidirectional_dynamic_rnn()函数的使用详解
2020/01/20 Python
Python 如何实现数据库表结构同步
2020/09/29 Python
GOOD AMERICAN官网:为曲线性感而设计
2017/12/28 全球购物
酒店员工检讨书
2014/02/18 职场文书
2014最新版群众路线四风整改措施
2014/09/24 职场文书
2014党的群众路线教育实践活动总结报告
2014/10/31 职场文书
学生会部长竞选稿
2015/11/19 职场文书
30岁前绝不能错过的10本书
2019/08/08 职场文书
从贫穷到富有,是知识技能和学习力的差别
2019/08/20 职场文书
《狼王梦》读后感:可怜天下父母心
2019/11/01 职场文书
怎么用Python识别手势数字
2021/06/07 Python
Python 中的Sympy详细使用
2021/08/07 Python