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 相关文章推荐
ejs v9 javascript模板系统
Mar 21 Javascript
Node.js实现简单聊天服务器
Jun 20 Javascript
javascript原生和jquery库实现iframe自适应高度和宽度
Jul 18 Javascript
js判断日期时间有效性的方法
Oct 24 Javascript
js浏览器html5表单验证
Oct 17 Javascript
node+express制作爬虫教程
Nov 11 Javascript
js实现鼠标拖拽多选功能示例
Aug 01 Javascript
bootstrap table实现点击翻页功能 可记录上下页选中的行
Sep 28 Javascript
vue使用keep-alive保持滚动条位置的实现方法
Apr 09 Javascript
vue+elementUI实现表格关键字筛选高亮
Oct 26 Javascript
nuxt踩坑之Vuex状态树的模块方式使用详解
Sep 06 Javascript
vue props default Array或是Object的正确写法说明
Jul 30 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递归调用与静态变量使用
2012/12/16 PHP
PHP图片等比例缩放生成缩略图函数分享
2014/06/10 PHP
php 判断IP为有效IP地址的方法
2018/01/28 PHP
PHP基于面向对象封装的分页类示例
2019/03/15 PHP
PHP商品秒杀问题解决方案实例详解【mysql与redis】
2019/07/22 PHP
javascript中巧用“闭包”实现程序的暂停执行功能
2007/04/04 Javascript
javascript mouseover、mouseout停止事件冒泡的解决方案
2009/04/07 Javascript
动态刷新 dorado树的js代码
2009/06/12 Javascript
javascript中检测变量的类型的代码
2010/12/28 Javascript
JS实现同时搜索百度和必应的方法
2015/01/27 Javascript
基于JS实现的笛卡尔乘积之商品发布
2016/05/13 Javascript
深入浅析JS的数组遍历方法(推荐)
2016/06/15 Javascript
详解jQuery的Cookie插件
2016/11/23 Javascript
H5上传本地图片并预览功能
2017/05/08 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)
2017/05/11 Javascript
vue中如何使用ztree
2018/02/06 Javascript
node 命令方式启动修改端口的方法
2018/05/12 Javascript
Vue Element 分组+多选+可搜索Select选择器实现示例
2018/07/23 Javascript
js 根据对象数组中的属性进行排序实现代码
2019/09/12 Javascript
JS实现滑动拼图验证功能完整示例
2020/03/29 Javascript
Python3基础之函数用法
2014/08/13 Python
Python实现的Excel文件读写类
2015/07/30 Python
django 发送手机验证码的示例代码
2018/04/25 Python
Python2与Python3的区别点整理
2019/12/12 Python
Python生成器generator原理及用法解析
2020/07/20 Python
CSS3盒子模型详解
2013/04/24 HTML / CSS
英国领先的葡萄酒专家:Majestic Wine
2017/05/30 全球购物
纽约通行卡:The New York Pass(免费游览纽约90多个景点)
2017/07/29 全球购物
致跳高运动员广播稿
2014/01/13 职场文书
父母寄语大全
2014/04/12 职场文书
委托证明范本
2014/11/25 职场文书
校本课程教学计划
2015/01/19 职场文书
Python Pygame实战在打砖块游戏的实现
2022/03/17 Python
Python 全局空间和局部空间
2022/04/06 Python
mysql中关键词exists的用法实例详解
2022/06/10 MySQL
Django框架中视图的用法
2022/06/10 Python