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父子组件之间的通信实例详解,包括了Vue父子组件之间的通信实例详解的使用技巧和注意事项,需要的朋友参考一下 在vue组件通信中其中最常见通信方式就是父子组件之中的通信,而父子组件的设定方式在不同情况下又各有不同。最常见的就是父组件为控制组件子组件为视图组件。父组件传递数据给子组件使用,遇到业务逻辑操作时子组件触发父组件的自定义事件。无论哪种组织方式父子组件的通信方式都是大同小
本文向大家介绍vue子父组件通信的实现代码,包括了vue子父组件通信的实现代码的使用技巧和注意事项,需要的朋友参考一下 之前在用vue写子父组件通信的时候,老是遇到问题!!! 子组件传值给父组件: 子组件:通过emit方法给父组件传值,这里的upparent是父组件要定义的方法 模板: 在data中定义:switchStatus = true; 方法: 父组件:模板:
本文向大家介绍vue之父子组件间通信实例讲解(props、$ref、$emit),包括了vue之父子组件间通信实例讲解(props、$ref、$emit)的使用技巧和注意事项,需要的朋友参考一下 组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用。那么组件间如何通信,也就成为了vue中重点知识了。这篇文章将会通过props、$ref和
本文向大家介绍Vue element-ui父组件控制子组件的表单校验操作,包括了Vue element-ui父组件控制子组件的表单校验操作的使用技巧和注意事项,需要的朋友参考一下 方法一: 父组件代码: //子组件代码 补充知识:vue element-ui表单验证无效解决方案 在写页面的时候用到的element-ui库中的表单验证 出现如下问题 表单验证效果已有 但验证功能不正确。 检查与对照官
子组件中的校验方法。 父组件中调用 父组件flag有时返回null,是什么原因?
本文向大家介绍vue2.0父子组件及非父子组件之间的通信方法,包括了vue2.0父子组件及非父子组件之间的通信方法的使用技巧和注意事项,需要的朋友参考一下 1.父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件: 子组件通过props来接收数据: 方式1: 方式2 : 方式3: 这样呢,就实现了父组件向子组件传递数据. 2.子组件与父组件通信 那么,如果子组