vue实现两个组件之间数据共享和修改

我们在使用vue开发过程中会遇到这样的情况,在父组件中引入了子组件,需要将父组件的值传到子组件中显示,同时子组件还可以更改父组件的值。

以我目前的一个项目的开发为例,如下图页面:
在这里插入图片描述
在父组件中,我引入了两个子组件,一个是左边的导航栏,还有中间的一个富文本编译器组件,当我点击左边导航栏时,中间的页面会切换,也就是改变引入的子组件。
怎么实现呢,首先,设置在该页面index.vue中设置一个变量index,左边导航栏每一项也对应一个index值,导航菜单绑定select函数,@select="handleSelect",@是v-on的简写。handleSelect函数接收到参数,然后发射出去,再由父组件接收就可以了。

			handleSelect(key, keyPath) {
                console.log(key, keyPath);
               this.changeIndex(keyPath[1])
            },
            changeIndex:function(key) {
                this.$emit("IndexChanged",key)
            }

this.$emit("IndexChanged",key)就是将key的值传到一个叫IndexChanged函数中,
在index.vue绑定IndexChanged接收值,<Aside v-on:IndexChanged="change($event)"> </Aside>然后调用change函数,注意$event是固定写法,接收的就是子页面传过来的key。然后就可以通过这个key改变index用来切换页面了。

下面通过一个更加简单直观的例子讲解一下,新建一个Test.vue:

<template>
  <div id="app">
  
  </div>
</template>
<script>
    export default{
        name:'Test',
        mounted() {

        },
    }
</script>

<style>

</style>

再建一个Test2.vue:

<template>

</template>

<script>
    export default {
        name: "Test2"
    }
</script>

<style scoped>

</style>

Test.vue是父组件,Test2.vue是子组件,下面先给Test配置路由,以便在浏览器上可以访问,为Test2定义模板,可以在Test中使用。
在router/index.js中添加下面代码

import Test from "../components/Test";
Vue.use(Router)

export default new Router({
  mode: 'history',
  routes: [
{
      path: '/t',
      name: 'Test',
      component: Test
    }
    ]
})

在main.js中,添加下面代码:

import Test2 from "./components/Test2";

Vue.use(Test2)
new Vue({
  el: '#app',
  router,
  components: {
    App,
 
    "Test2":Test2

  },

  template: '<App/>'
})

现在在test2页面写上这样一句,

<template>
<div>
  {{text2}}
</div>
</template>

<script>
    export default {
        name: "Test2",
        data(){
            return{
                text2:"这是Test2页面"
            }
        }

    }
</script>

<style scoped>

</style>

在test中引入test2,同时也定义一个变量text,然后显示在页面上,代码如下:

<template>
  <div id="app">
  {{text1}}
    <Test2></Test2>

  </div>
</template>
<script>


    import Test2 from "./Test2";
    export default{
        name:'Test',
        components: {Test2},
        data(){
            return{
                text1:"这是Test1页面"
            }
        },
        mounted() {

        },
    }
</script>

<style>

</style>


浏览器访问http://localhost:8080/t,页面如下:
在这里插入图片描述
现在要实现Test2接收Test1的值并显示:
绑定数据用v-bind

 <Test2 v-bind:text1="text1"></Test2>

传的数据是Test页面的text1,命名也是text1,可以不同,但接收时的名字和第一个要相同。
Test2页面要接收数据啊,通过props接收:

props: ['text1'],

接收之后可以把它传给text2,也可以直接在页面显示:

<template>
<div>
  {{text2}}
  {{text1}}
</div>
</template>

<script>
    export default {
        name: "Test2",
        props: ['text1'],
        data(){
            return{
                text2:"这是Test2页面"
            }
        }

    }
</script>

<style scoped>

</style>

在这里插入图片描述
接收到text1值了,怎么同步更改呢,需要再绑定一个函数,如下:

<Test2 v-bind:text1="text1" v-on:textChanged="change($event)"></Test2>
....
methods: {
            change(msg){
                this.text1 = msg;
            }

        },

在test2中,将值发射到textChanged就可以了

mounted() {
            this.$emit("textChanged","我改了text1的值")
        }

在这里插入图片描述

版权声明:本文为jingyoushui原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/jingyoushui/article/details/102756604

智能推荐

使用QProcess打开和关闭第三方应用,比如CMD

使用QProcess打开和关闭第三方应用,比如CMD 注意: 很多教程不一定是对的,但我这篇绝对是对的,因为我踩坑过啊。 为了节省时间,直接上图、上代码,so easy! 重要事情说3遍: 杀死进程,一定要加/F 和 /T 杀死进程,一定要加/F 和 /T 杀死进程,一定要加/F 和 /T 开始 验证下,打开任务管理器就能看到 总结 从上面看,是不是很简单,taskkill不知道是啥,是windo...

自定义View实现注销图案的加载动画

先看效果图: 有那味了。。。(懂得都懂^ ^ √) 我们先来分析一下怎么画,然后再研究怎么让他动起来 这个View是由内部的注销图案和外面一圈圆环构成。而内部的注销图案又是由一个基本满角度的圆弧和一根竖线组成 一、绘制内部注销图案 首先初始化画笔和圆弧的外切矩形: 圆弧的中心是View的中心,坐标为(getWidth()/2,getWidth()/2),半径设置为getWidth/4,...

vue3使用vue-count-to组件

项目场景: 数据可视化大屏开发的过程中,需要实现一种滚动数字的效果,在使用vue2时,使用vue-count-to完全没有问题,功能也比较完善(滚动时长,开始值,结束值,前缀,后缀,千分隔符,小数分隔符等等),但是在vue3中使用会出现问题。 展示的效果 问题描述: 出现的错误时 == Cannot read property ‘_c’ of undefined== 这是一...

【java设计模式】中介者模式

步骤一:创建 中介者 Mediator 步骤二:建立具体中介者 实现者 步骤三:建立同事类接口 User 步骤四:建立同事类的具体实现类 步骤五:测试...

包的安装

包的分类: 包的安装方式: 1. yum 安装 不需要手动解决依赖关系 本地yum源配置:不需要网络 网络源配置 yum : 2. 源码安装 2.1 安装准备: 2.2 分析安装平台环境 查看安装平台参数,下载合适的包 2.3 下载源码包 根据查到的参数下载源码包,建议下载到/usr/local/src目录下 2.4 安装源码包 示例: 此处以apache http示例:https://mirro...

猜你喜欢

李洪义机器学习课程(一)——Learning Map学习笔记

  我们先一张一张PPT来分析讲解[1]。 总体框图 : 这张图表明了接下来的知识脉络体系,也可以看成目前学术界、工业界的几大研究方向。整体上分为: 监督学习、半监督学习、无监督学习、迁移学习、强化学习。 对于监督学习又分为:回归、分类、结构化学习[2] 对于分类问题,整体上分为线性模型和非线性模型,非线性模型包括深度学习、SVM、决策树、KNN等。 接下来一个一个说明。  李大大对回归有一个例子...

druid配置和后台监控

最简单快速的druid配置 1.pom.xml 引入依赖包 2.spring.xml配置druid 3.web.xml配置 4.启动Tomcat服务器,输入localhost:8080/你的项目名/druid MISSION COMPLETED!...

week14作业

B - Q老师与十字叉(必做) 解题思路: 首先,这个题目并不是很难,第一反应是和我们第三次csp模拟的第二题有些类似,一开始也就直接对每个点进行暴力遍历,但这道题目的数据量偏大,这样肯定会TLE。我们应当采取更有效的做法。其实对于一个点的检验便是对一行一列的检验,我们不能简单的当用到某一行某一列时才去计算它,这样会有很多的重复性工作,我们可以将每一行每一列计算好等待备用。我对这道题目感触比较大的...

Redis持久化

文章目录 持久化是什么? 正文 1.1RDB save 1.2bgsave指令 1.3. save配置自动执行 2.1 AOF概念 2.2 AOF执行策略 2.3 AOF重写 2.4 AOF工作流程及重写流程 RDB与AOF区别 RDB与AOF对比(优缺点) RDB与AOF应用场景 持久化是什么? (1)什么事持久化? 利用永久性存储介质将数据进行保存,在特定的时间将保存的数据进行恢复的工作机制称...

Leetcode--寻找最长公共前缀(二分查找法)

编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀,返回空字符串 “”。 示例 1: startsWith(String s):判断字符串是否以指定字符或子字符串开头。...