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基础的动画教程,直观易懂
Jan 10 Javascript
javascript操作文本框readOnly
May 15 Javascript
javascript 精粹笔记
May 09 Javascript
javascript动态判断html元素并执行不同的操作
Jun 16 Javascript
JavaScript函数定义的常见注意事项小结
Sep 16 Javascript
将数字转换成大写的人民币表达式的js函数
Sep 21 Javascript
jquery简单实现图片切换效果的方法
May 12 Javascript
jQuery移动页面开发中的触摸事件与虚拟鼠标事件简介
Dec 03 Javascript
EasyUI创建人员树的实例代码
Sep 15 Javascript
Vue EventBus自定义组件事件传递
Jun 25 Javascript
vue点击标签切换选中及互相排斥操作
Jul 17 Javascript
Webpack的Loader和Plugin的区别
Nov 09 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
深入浅析Yii admin的权限控制
2016/08/31 PHP
PHP使用观察者模式处理异常信息的方法详解
2019/09/24 PHP
在laravel5.2中实现点击用户头像更改头像的方法
2019/10/14 PHP
ExtJS DOM元素操作经验分享
2013/08/28 Javascript
jquery与js函数冲突的两种解决方法
2013/09/09 Javascript
javascript中不提供sleep功能如何实现这个功能
2014/05/27 Javascript
浅谈jQuery中的事件
2015/03/23 Javascript
jquery实现九宫格大转盘抽奖
2015/11/13 Javascript
jquery实用技巧之输入框提示语句
2016/07/28 Javascript
js方法数据验证的简单实例
2016/09/17 Javascript
canvas快速绘制圆形、三角形、矩形、多边形方法介绍
2016/12/29 Javascript
微信小程序 数组中的push与concat的区别
2017/01/05 Javascript
JQuery选中select组件被选中的值方法
2018/03/08 jQuery
layerUI下的绑定事件实例代码
2018/08/17 Javascript
vuex直接赋值的三种方法总结
2018/09/16 Javascript
老生常谈JavaScript获取CSS样式的方法(兼容各浏览器)
2018/09/19 Javascript
基于layui实现高级搜索(筛选)功能
2019/07/26 Javascript
Swiper.js实现移动端元素左右滑动
2019/09/08 Javascript
基于NodeJS开发钉钉回调接口实现AES-CBC加解密
2020/08/20 NodeJs
vue中如何自定义右键菜单详解
2020/12/08 Vue.js
关于小程序优化的一些建议(小结)
2020/12/10 Javascript
vue实现树状表格效果
2020/12/29 Vue.js
python3.x上post发送json数据
2018/03/04 Python
Python openpyxl读取单元格字体颜色过程解析
2019/09/03 Python
python归并排序算法过程实例讲解
2020/11/04 Python
Python中BeautifulSoup通过查找Id获取元素信息
2020/12/07 Python
HTML5 weui使用笔记
2019/11/21 HTML / CSS
video.js支持m3u8格式直播的实现示例
2020/05/20 HTML / CSS
Sisley法国希思黎中国官网:享誉全球的奢华植物美容品牌
2019/06/30 全球购物
小学三年级数学教学反思
2014/01/31 职场文书
关于元旦的广播稿
2014/02/16 职场文书
经理秘书求职自荐信范文
2014/03/23 职场文书
会议接待欢迎标语
2014/10/08 职场文书
2016五四青年节活动总结范文
2016/04/06 职场文书
如何制定一份可行的计划!
2019/06/21 职场文书
德劲DE1102数字调谐收音机机评
2022/04/07 无线电