摘要:组件是 vue.js最强大的功能之一,这五个组件间传值场景你了解吗?

本文分享自华为云社区《你了解Vue组件间传值五大场景吗?》,作者:北极光之夜。 。

父组件向子组件传值:

比如有一个 Father.vue 的父组件要传值给 Children.vue 的子组件,完成共需四步:

父组件 Father.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>父组件区域</h2>
<hr />
<!-- 第二步:在引用的子组件标签里定义 :num="num" , num就是要传递的变量-->
<Children :num="num"></Children>
</div>
</template> <script>
// 引入子组件
import Children from "./Children.vue";
export default {
data() {
return {
// 第一步:我们将要把变量 num 的值传给子组件Children
num: 666,
};
},
components: {
Children,
},
};
</script>

子组件 Children.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>子组件区域</h2>
<!-- 第四步:在子组件显示父组件传过来的值 -->
<i>父组件传递过了的值:{{ num }}</i>
</div>
</template>
<script>
export default {
//第三步: 子组件可以通过定义的props就可以接收来自父组件的变量值 num
props: ["num"],
data() {
return {};
},
};
</script>

运行效果:

子组件向父组件传值:

比如有一个 Children.vue 的子组件要传值给 Father.vue 的父组件,完成共需六步:

子组件 Children.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>子组件区域</h2>
<!-- 第二步:得定义一个向父组件传值的方法,比如定义一个按钮,
绑定一个点击事件,触发giveFather方法 -->
<button @click="giveFather">giveFather</button>
</div>
</template>
<script>
export default {
data() {
return {
// 第一步:我们将要把变量 word 的值传给父组件
word: "北极光之夜。",
};
},
methods: {
// 第三:定义子组件向父组件传值的事件方法
giveFather() {
// 第四步:可以通过$emit传值给父组件,第一个参数为传值的方法,第二个参数为要传递的值
this.$emit("giveFather", this.word);
},
},
};
</script>

父组件 Father.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>父组件区域</h2>
<hr />
<!-- 第五步:要在引用的子组件标签里定义一个自定义事件,
该自定义事件要写为子组件$emit的第一个参数一样,
然后双引号里的方法可以自定义,我这就为getSon -->
<Children @giveFather="getSon"></Children>
</div>
</template> <script>
// 引入子组件
import Children from "./Children.vue"; export default {
data() {
return {};
},
components: {
Children,
},
methods: {
//第六步:定义获取子组件值的方法,该方法的参数就为子组件传递过来的值
getSon(temp) {
// 控制台输出看看能不能获取
console.log(temp);
},
},
};
</script>

运行效果:

 

兄弟组件间传值:

比如有一个 Father.vue 的父组件,它有一个Children.vue 的子组件和一个Son.vue 的子组件,那么,Children.vue 和 Son.vue 就是兄弟关系,现在 Children.vue 要向兄弟 Son.vue 传值:

首先在vue原型上定义一个新的实例,main.js文件内容,注意里面的操作步骤:

import Vue from 'vue'
import App from './App.vue' Vue.config.productionTip = false // 第一步,在vue原型上定义一个自己的方法,一般叫$bus,为vue实例
Vue.prototype.$bus = new Vue(); new Vue({
render: h => h(App),
}).$mount('#app')

Children.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>Children子组件区域</h2>
<!-- 第三步:定义一个向兄弟组件传值的方法,比如定义一个按钮,
绑定一个点击事件,触发giveSon方法 -->
<button @click="giveSon">giveSon</button>
</div>
</template>
<script>
export default {
data() {
return {
// 第二步:我们将要把变量 word 的值传给兄弟组件
word: "北极光之夜。",
};
},
methods: {
// 第四:定义子组件向兄弟组件传值的事件方法
giveSon() {
// 第五步:可以通过自定义的$bus的$emit传值给兄弟组件,
//第一个参数为传值的方法,第二个参数为要传递的值
this.$bus.$emit("giveSon", this.word);
},
},
};
</script>

Son.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>Son子组件区域</h2>
</div>
</template>
<script>
export default {
data() {
return {};
},
created() {
//第六步:通过$on方法进行获取兄弟传递过来的值。
//第一个参数为兄弟组件传值的方法,第二个参数是自定义的方法
this.$bus.$on("giveSon", this.getSon);
},
methods: {
//第七步,自定义的方法,参数就是兄弟传过来的值
getSon(temp) {
//输出看看
console.log(temp);
},
},
};
</script>

运行效果:

总结就是,在vue原型上定义一个新的实例, 然后采用 emit 和emit和 on 这两个方法进行获取传递过来的值。

使用Vuex状态机传值:

Vuex是实现组件全局状态(数据)管理的一种机制,可以很方便的实现组件之间数据的共享。

关于Vuex的详细使用,可以看这篇文章,指路https://auroras.blog.csdn.net/article/details/117536679

给后代组件传值,provide和inject:

比如有一个 Father.vue 的父组件,它有一个Children.vue 的子组件,那么这个Children.vue 的子组件是他的后代。而若Children.vue 也有一个子组件 grandSon.vue,那么grandSon.vue 就相当于 Father.vue的孙子组件,同样,grandSon.vue也会是Father.vue的后代。以此类推,它的孙子,孙子的孙子等等都是它后代。现在我们实现Father.vue 给它的后代grandSon.vue孙子组件传值:

父组件 Father.vue 内容,注意里面的操作步骤:

<template>
<div>
<h2>父组件区域</h2>
<hr />
<Children></Children>
</div>
</template> <script>
// 引入子组件
import Children from "./Children.vue";
export default {
data() {
return {
// 第一步:定义一个变量,我们将要把变量 num 的值传给后代组件grandSon.vue
num: "北极光之夜",
};
},
// 第二步,定义一个provide函数
provide() {
//第三步,如下定义,给后代接收
//giveAfter名称为自己定义,任意起,this固定写法
return {
giveAfter: this,
};
},
components: {
Children,
},
};
</script>

子组件Children.vue 内容,没什么,引入子组件就行:

<template>
<div>
<h2>
Children子组件区域
<hr />
<Grand-son></Grand-son>
</h2>
</div>
</template>
<script>
// 引入子组件
import GrandSon from "./GrandSon.vue";
export default {
data() {
return {};
}, components: {
GrandSon,
},
};
</script>

孙子组件GrandSon.vue 内容,注意里面的操作步骤:

 <template>
<div>
GrandSon孙子组件区域
<!-- 第六步:展示数据 -->
<i> {{ num }}</i>
</div>
</template>
<script>
export default {
//第四步:定义inject,里面写祖先组件自定义的名称
inject: ["giveAfter"],
data() {
return {
// 第五步:取得祖先组件传的值,this.giveAfter.要传递值的变量名
//赋值给num
num: this.giveAfter.num,
};
},
};
</script>

看运行效果,成功获取:

点击关注,第一时间了解华为云新鲜技术~

Vue组件间的传值五大场景,你造吗?的更多相关文章

  1. Vue 组件间的传值(通讯)

    组件之间的通讯分为三种 父给子传 子给父传 兄弟组件之间的通讯 1 父组件给子组件传值 子组件嵌套在父组件内部,父组件给子组件传递一个标识,在子组件内部用props接收,子组件在模板里可以通过{{}} ...

  2. vue组件间的传值方式及方法调用汇总

    1.传值 a.父组件传子组件 方法一: 父页面: <myReportContent v-if="contentState==1" :paramsProps='paramsPr ...

  3. [Props] vue组件间的传值及校验

    基本用法 Prop的基本用法很简单,只需要在子组件的Vue实例中定义该属性并把值设为目标属性的数组即可 Vue.component('child', { ... // 接收message props: ...

  4. Vue 组件间传值

    前言 Vue 作为现在比较火的框架之一,相信您在使用的过程中,也会遇到组件间传值的情况,本文将讲解几种 Vue 组件间传值的几种方法,跟着小编一起来学习一下吧! 实现 注意: 学习本文,需要您对 Vu ...

  5. vue组件定义方式,vue父子组件间的传值

    vue组件定义方式,vue父子组件间的传值 <!DOCTYPE html> <html lang="zh-cn"> <head> <met ...

  6. Vue—非父子组件间的传值(Bus/发布订阅模式/观察者模式/总线)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. vue组件间通信六种方式(完整版)

    本文总结了vue组件间通信的几种方式,如props. $emit/ $on.vuex. $parent / $children. $attrs/ $listeners和provide/inject,以 ...

  8. Vue组件间通信6种方式

    摘要: 总有一款合适的通信方式. 作者:浪里行舟 Fundebug经授权转载,版权归原作者所有. 前言 组件是 vue.js 最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的 ...

  9. Vue框架:6、Vue组件间通信,动态组件,插槽,计算属性,监听属性

    目录 前端开发之Vue框架 一.Vue组件间通信 1.组件间通讯父传子 2.组件间通讯子传父 3.ref属性 二.动态组件 1.不使用动态组件 2.使用动态组件 3.keep-alive保持组件不销毁 ...

  10. Vue组件间通信-Vuex

    上回说到Vue组件间通讯,最后留了一个彩蛋~~~Vuex.Vuex是另一种组件通讯的方法,这节来说说Vuex(store仓库). 首先Vuex需要安装,安装的方式有很多,在这里就不一一细说了.我是通过 ...

随机推荐

  1. Linux发行版部分时间线

  2. C++基础杂记(3)

    类的继承 基类与派生类之间的构造行为 在派生类中使用基类方法 protected 的访问权限 多态公有继承 关键字 virtual 示例 抽象基类(ABC) 私有继承和保护继承 多重继承 类的继承 基 ...

  3. 【译】NoClassDefFoundError和ClassNotFoundException的不同(转)

    https://www.jianshu.com/p/93d0db07d2e3 本文翻译自:Difference between NoClassDefFoundError vs ClassNotFoun ...

  4. 自定义Graph Component:1.2-其它Tokenizer具体实现

      本文主要介绍了Rasa中相关Tokenizer的具体实现,包括默认Tokenizer和第三方Tokenizer.前者包括JiebaTokenizer.MitieTokenizer.SpacyTok ...

  5. 编译wasm Web应用

    刚学完WebAssembly的入门课,卖弄一点入门知识. 首先我们知道wasm是目标语言,是一种新的V-ISA标准,所以编写wasm应用,正常来说不会直接使用WAT可读文本格式,更不会用wasm字节码 ...

  6. Python 潮流周刊#27:应该如何处理程序的错误?

    你好,我是猫哥.这里每周分享优质的 Python.AI 及通用技术内容,大部分为英文.本周刊开源,欢迎投稿.另有电报频道作为副刊,补充发布更加丰富的资讯. 产品推荐 Walles.AI 是一款适用于所 ...

  7. java.util.List如何用

    起因是这样,我在学习Javaweb,然后就突然有很多类似的语句 这是什么意思呢?让我们一起来解决看看吧! List有序集合(也成为序列),用户可以精确控制列表中每个元素的插入位置.用户可以通过整数索引 ...

  8. Vue入门(1)安装vue环境,创建Vue2 Vue3的项目并且安装IIS环境和发布到IIS

    Vue环境的搭建 一.     背景 vue的运行方式有两种 一种是在页面引用vue的js包, 一种是搭建脚手架来vue框架. 我们在这里使用的是第二种方式. 需要安装的软件 npm 16.13.1 ...

  9. LR(0)分析法

    LR(0)是一种自底向上的语法分析方法.两个基本动作是移进和规约. 具体例子如下 已知文法G[E] (1) E→aА (2) E→bB (3) A→cА (4) A→d (5) B→cB (6) B→ ...

  10. Educational Codeforces Round 160 (Rated for Div. 2) 题解A~D

    Educational Codeforces Round 160 (Rated for Div. 2) A. Rating Increase 纯暴力,分割字符串,如果n1<n2就输出,如果遍历完 ...