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 相关文章推荐
datagrid框架的删除添加与修改
Apr 08 Javascript
JavaScript中发布/订阅模式的简单实例
Nov 05 Javascript
Javascript学习笔记之数组的遍历和 length 属性
Nov 23 Javascript
JavaScript中的继承方式详解
Feb 11 Javascript
手机端页面rem宽度自适应脚本
May 20 Javascript
Javascript小技能总结(推荐)
Jun 02 Javascript
Bootstrap模态框使用详解
Feb 15 Javascript
JS Input里添加小图标的两种方法
Nov 11 Javascript
一次记住JavaScript的6个正则表达式方法
Feb 22 Javascript
Vue中插入HTML代码的方法
Sep 21 Javascript
vue+koa2实现session、token登陆状态验证的示例
Aug 30 Javascript
jsonp格式前端发送和后台接受写法的代码详解
Nov 07 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和ACCESS写聊天室(二)
2006/10/09 PHP
PHP的范围解析操作符(::)的含义分析说明
2011/07/03 PHP
Notice: Trying to get property of non-object problem(PHP)解决办法
2012/03/11 PHP
用PHP提取中英文词语以及数字的首字母的方法介绍
2013/04/23 PHP
thinkPHP5分页功能实现方法分析
2017/10/25 PHP
Ext 今日学习总结
2010/09/19 Javascript
javascript loadScript异步加载脚本示例讲解
2013/11/14 Javascript
从QQ网站中提取的纯JS省市区三级联动菜单
2013/12/25 Javascript
jquery实现的网页自动播放声音
2014/04/30 Javascript
javascript中一些util方法汇总
2015/06/10 Javascript
JS中常用的输出方式(五种)
2016/06/12 Javascript
js遍历获取表格内数据的方法(必看)
2017/04/06 Javascript
express+mockjs实现模拟后台数据发送功能
2018/01/07 Javascript
JavaScript中arguments和this对象用法分析
2018/08/08 Javascript
Nuxt.js实现校验访问浏览器类型的中间件
2018/08/24 Javascript
原生JS实现简单的无缝自动轮播效果
2018/09/26 Javascript
vue项目环境变量配置的实现方法
2018/10/12 Javascript
vue 基于element-ui 分页组件封装的实例代码
2018/12/10 Javascript
微信小程序中转义字符的处理方法
2019/03/28 Javascript
Vue实现简单购物车功能
2020/12/13 Vue.js
Vue看了就会的8个小技巧
2021/01/21 Vue.js
使用PDB模式调试Python程序介绍
2015/04/05 Python
详解python使用递归、尾递归、循环三种方式实现斐波那契数列
2018/01/16 Python
Django读取Mysql数据并显示在前端的实例
2018/05/27 Python
TensorFlow内存管理bfc算法实例
2020/02/03 Python
Python双链表原理与实现方法详解
2020/02/22 Python
CSS3 animation实现简易幻灯片轮播特效
2016/09/27 HTML / CSS
如何使用localstorage代替cookie实现跨域共享数据问题
2018/04/18 HTML / CSS
深入解析HTML5的IndexedDB索引数据库
2015/09/14 HTML / CSS
伯克斯奥特莱斯:Burkes Outlet
2019/03/30 全球购物
英文版餐饮业求职信
2013/10/18 职场文书
个人自我鉴定写法
2013/11/30 职场文书
车间操作工岗位职责
2013/12/19 职场文书
高校辅导员推荐信范文
2013/12/25 职场文书
愚人节活动策划方案
2014/03/11 职场文书
班级课外活动总结
2014/07/09 职场文书