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 相关文章推荐
神奇的代码 通杀各种网站-可随意修改复制页面内容
Jul 17 Javascript
jQuery 淡入淡出 png图在ie8下有黑色边框的解决方法
Mar 05 Javascript
jQuery实现的多选框多级联动插件
May 02 Javascript
jQuery filter函数使用方法
May 19 Javascript
老生常谈js动态添加事件--- 事件委托
Jul 19 Javascript
轻松掌握JavaScript享元模式
Aug 27 Javascript
AngularJS实现网站换肤实例
Feb 19 Javascript
详解JS获取HTML DOM元素的8种方法
Jun 17 Javascript
JS代码实现电脑配置检测功能
Mar 21 Javascript
node.js使用net模块创建服务器和客户端示例【基于TCP协议】
Feb 14 Javascript
简单了解Vue + ElementUI后台管理模板
Apr 07 Javascript
JavaScript原型链中函数和对象的理解
Jun 16 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 trim 去除空字符的定义与语法介绍
2010/05/31 PHP
PHP编码规范的深入探讨
2013/06/06 PHP
php过滤HTML标签、属性等正则表达式汇总
2014/09/22 PHP
PHP使用SOAP扩展实现WebService的方法
2016/04/01 PHP
php对微信支付回调处理的方法
2018/08/23 PHP
js Date自定义函数 延迟脚本执行
2010/03/10 Javascript
javascript中的107个基础知识收集整理 推荐
2010/03/29 Javascript
javascript结合html5 canvas实现(可调画笔颜色/粗细/橡皮)的涂鸦板
2013/04/27 Javascript
JavaScript伸缩的菜单简单示例
2013/12/03 Javascript
js控制input框只读实现示例
2014/01/20 Javascript
JS实现的颜色实时渐变效果完整实例
2016/03/25 Javascript
Bootstrap学习系列之使用 Bootstrap Typeahead 组件实现百度下拉效果
2016/07/07 Javascript
JavaScript限定范围拖拽及自定义滚动条应用(3)
2017/05/17 Javascript
Bootstrap响应式导航由768px变成992px的实现代码
2017/06/15 Javascript
jQuery实现获取table中鼠标click点击位置行号与列号的方法
2017/10/09 jQuery
JS实现的找零张数最小问题示例
2017/11/28 Javascript
微信小程序ibeacon三点定位详解
2018/10/31 Javascript
js如何获取图片url的Blob值并预览示例代码
2019/03/07 Javascript
实例详解vue中的$root和$parent
2019/04/29 Javascript
JS html事件冒泡和事件捕获操作示例
2019/05/01 Javascript
在Vuex中Mutations修改状态操作
2020/07/24 Javascript
解决vue axios跨域 Request Method: OPTIONS问题(预检请求)
2020/08/14 Javascript
python在windows下实现备份程序实例
2014/07/04 Python
利用Python实现在同一网络中的本地文件共享方法
2018/06/04 Python
python3发送邮件需要经过代理服务器的示例代码
2019/07/25 Python
Python3.7实现验证码登录方式代码实例
2020/02/14 Python
Tensorflow加载Vgg预训练模型操作
2020/05/26 Python
法国面料和小百货在线商店:Mondial Tissus
2019/03/23 全球购物
个性化皮包、小袋、生活配件:Mon Purse
2019/03/26 全球购物
建筑装饰学院室内设计专业个人自我评价
2013/12/07 职场文书
工作自荐信
2013/12/11 职场文书
国窖1573广告词
2014/03/21 职场文书
2014党员民主评议个人思想剖析发言
2014/09/19 职场文书
房屋鉴定委托书范本
2014/09/23 职场文书
学校运动会报道稿
2014/09/23 职场文书
2016小学教师读书心得体会
2016/01/13 职场文书