Vue 组件间传值
栏目: JavaScript · 发布时间: 5年前
内容简介:Vue 作为现在比较火的框架之一,相信您在使用的过程中,也会遇到组件间传值的情况,本文将讲解几种 Vue 组件间传值的几种方法,跟着小编一起来学习一下吧!注意: 学习本文,需要您对 Vue 有一定的了解。为了便于讲解,以下方法均假设父组件是 FatherComponent,子组件是 ChildComponent,兄弟组件是:BrotherComponent。我们来假定一种场景:点击父组件“传递给子组件”按钮,向子组件传递一条消息“I am your father.”;点击子组件“传递给父组件”按钮,向父组件
前言
Vue 作为现在比较火的框架之一,相信您在使用的过程中,也会遇到组件间传值的情况,本文将讲解几种 Vue 组件间传值的几种方法,跟着小编一起来学习一下吧!
实现
注意: 学习本文,需要您对 Vue 有一定的了解。
为了便于讲解,以下方法均假设父组件是 FatherComponent,子组件是 ChildComponent,兄弟组件是:BrotherComponent。我们来假定一种场景:点击父组件“传递给子组件”按钮,向子组件传递一条消息“I am your father.”;点击子组件“传递给父组件”按钮,向父组件传递一条消息“I am your child.”;点击子组件“传递给兄弟组件”按钮,向兄弟组件传递一条消息“I am your brother.”
1. 方法一
关键词: props、$emit
父组件 FatherComponent 代码:
<template> <div> <div>{{toFatherInfo}}</div> <ChildComponent :toChildInfo="toChildInfo" @toFather="toFather" @toBrother="toBrother"/> <BrotherComponent :toBrotherInfo="toBrotherInfo"/> <button @click="toChild">传递给子组件</button> </div> </template> <script> import ChildComponent from 'components/test/child-component' import BrotherComponent from 'components/test/brother-component' export default { components: { ChildComponent, BrotherComponent }, data () { return { toFatherInfo: '', toChildInfo: '', toBrotherInfo: '' } }, methods: { toFather (res) { this.toFatherInfo = res }, toBrother (res) { this.toBrotherInfo = res }, toChild () { this.toChildInfo = 'I am your father.' } } } </script> <style lang="less"> button { font-size: 36px; border: none; padding: 20px; background-color: #999; color: #fff; width: 100%; margin-top: 30px; } </style>
子组件 ChildComponent 代码:
<template> <div> <div>{{toChildInfo}}</div> <button @click="toFather">传递给父组件</button> <button @click="toBrother">传递给兄弟组件</button> </div> </template> <script> export default { props: { toChildInfo: { type: String } }, methods: { toFather () { this.$emit('toFather', 'I am your child.') }, toBrother () { this.$emit('toBrother', 'I am your brother.') } } } </script> <style lang="less"> </style>
兄弟组件 BrotherComponent 代码:
<template> <div>{{toBrotherInfo}}</div> </template> <script> export default { props: { toBrotherInfo: { type: String } } } </script> <style lang="less"> </style>
通过上面代码,不难发现,我们通过使用 props 来实现父组件给子组件传值;子组件向父组件传值时,借助 $emit 来实现;而子组件向兄弟组件传值时,将两者结合起来使用。
2. 方法二
关键词:独立的事件中心 eventHub
首先需要先创建 eventHub.js 文件,代码如下:
// 将在各处使用该事件中心 // 组件通过它来通信 import Vue from 'vue' export default new Vue()
然后在组件中,可以使用 $emit, $on, $off 分别来分发、监听、取消监听事件。
父组件 FatherComponent 代码:
<template> <div> <div>{{info}}</div> <ChildComponent /> <BrotherComponent /> <button @click="toChild">传递给子组件</button> </div> </template> <script> import eventHub from '../../components/test/eventHub' import ChildComponent from 'components/test/child-component' import BrotherComponent from 'components/test/brother-component' export default { components: { ChildComponent, BrotherComponent }, data () { return { info: '' } }, created: function () { eventHub.$on('toFather', this.toFather) }, // 最好在组件销毁前 // 清除事件监听 beforeDestroy: function () { eventHub.$off('toFather', this.toFather) }, methods: { toFather (res) { this.info = res }, toChild () { eventHub.$emit('toChild', 'I am your father.') } } } </script> <style lang="less"> button { font-size: 36px; border: none; padding: 20px; background-color: #999; color: #fff; width: 100%; margin-top: 30px; } </style>
子组件 ChildComponent 代码:
<template> <div> <div>{{info}}</div> <button @click="toFather">传递给父组件</button> <button @click="toBrother">传递给兄弟组件</button> </div> </template> <script> import eventHub from './eventHub' export default { data () { return { info: '' } }, created: function () { eventHub.$on('toChild', this.toChild) }, // 最好在组件销毁前 // 清除事件监听 beforeDestroy: function () { eventHub.$off('toChild', this.toChild) }, methods: { toChild (res) { this.info = res }, toFather () { eventHub.$emit('toFather', 'I am your child.') }, toBrother () { eventHub.$emit('toBrother', 'I am your brother.') } } } </script> <style lang="less"> </style>
兄弟组件 BrotherComponent 代码:
<template> <div>{{info}}</div> </template> <script> import eventHub from './eventHub' export default { data () { return { info: '' } }, created: function () { eventHub.$on('toBrother', this.toBrother) }, // 最好在组件销毁前 // 清除事件监听 beforeDestroy: function () { eventHub.$off('toBrother', this.toBrother) }, methods: { toBrother (res) { this.info = res } } } </script> <style lang="less"> </style>
3. 方法三
关键词:Vuex
我们需要创建 store.js 来存放数据:
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) export default new Vuex.Store({ state: { fromFatherInfo: '', fromChildInfo: '', fromBrotherInfo: '' }, mutations: { changeFromFatherInfo (state, fromFatherInfo) { state.fromFatherInfo = fromFatherInfo }, changeFromChildInfo (state, fromChildInfo) { state.fromChildInfo = fromChildInfo }, changeFromBrotherInfo (state, fromBrotherInfo) { state.fromBrotherInfo = fromBrotherInfo } } })
实例化:
import Vue from 'vue' import App from './App' import store from './store' new Vue({ el: '#app', store, template: '<App/>', components: { App } })
父组件 FatherComponent 代码:
<template> <div> <div>{{fromChildInfo}}</div> <ChildComponent /> <BrotherComponent /> <button @click="toChild">传递给子组件</button> </div> </template> <script> import ChildComponent from 'components/test/child-component' import BrotherComponent from 'components/test/brother-component' export default { components: { ChildComponent, BrotherComponent }, computed: { fromChildInfo () { return this.$store.state.fromChildInfo } }, methods: { toChild () { this.$store.commit('changeFromFatherInfo', 'I am your father.') } } } </script> <style lang="less"> button { font-size: 36px; border: none; padding: 20px; background-color: #999; color: #fff; width: 100%; margin-top: 30px; } </style>
子组件 ChildComponent 代码:
<template> <div> <div>{{fromFatherInfo}}</div> <button @click="toFather">传递给父组件</button> <button @click="toBrother">传递给兄弟组件</button> </div> </template> <script> export default { computed: { fromFatherInfo () { return this.$store.state.fromFatherInfo } }, methods: { toFather () { this.$store.commit('changeFromChildInfo', 'I am your child.') }, toBrother () { this.$store.commit('changeFromBrotherInfo', 'I am your brother.') } } } </script> <style lang="less"> </style>
兄弟组件 BrotherComponent 代码:
<template> <div>{{fromBrotherInfo}}</div> </template> <script> export default { computed: { fromBrotherInfo () { return this.$store.state.fromBrotherInfo } } } </script> <style lang="less"> </style>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- React 组件模式-有状态组件 x 无状态组件、容器组件 x 展示组件、高阶组件 x 渲染回调(函数作为子组件)
- Serverless 组件开发尝试:全局变量组件和单独部署组件
- angular自定义组件-UI组件篇-switch组件
- React Hooks 源码解析(一):类组件、函数组件、纯组件
- Vue动态组件和异步组件
- Vue 动态组件 & 异步组件原理
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法设计与实验题解
王晓东 / 电子工业 / 2006-9 / 46.00元
《算法设计与实验题解》是与普通高等教育“十一五”国家级规划教材《计算机算法设计与分析》(第2版)配套的辅助教材,对主教材中的全部习题做了解答或给出了解题思路提示,并对主教材的内容进行了扩展,有些主教材中无法讲述的较深入的主题以习题的形式展现出来。为了提高学生解决实际问题的能力,《算法设计与实验题解》还将主教材中的许多习题改造成算法实现题,要求学生设计出算法并上机实现。作者还结合精品课程建设,进行了......一起来看看 《算法设计与实验题解》 这本书的介绍吧!