Vue--子组件传值,子组件来回传值,子组件传值反复横跳

我不不仅要子组件之间直接传值,我还要传过去再传回来,传回来再传过去,子组件直接反复横跳

解决问题

  1. 给组件传值,并不知道改值的校验结果
  2. 同一个组件,在不同的引用中校验方式完全不一样,需要将校验方式放到组件外面的情况

单项发送

  • 子组件一发送参数
send1() {
this.pVue.$emit('send1', {
code: this.code
})
},
  • 子组件二接收参数
this.pVue.$on('send1', data => {
this.code1 = data.code
console.log(`表格组件 => 接收参数 ${data.code}`)
this.pVue.boo = true
})

发送并接收回参

子组件一发送,子组件二接收,进行逻辑处理后返回组件一

  • 子组件一
send2() {
this.pVue.$emit('send2', {
code: this.code
}, (data) => {
console.log(`按钮组件 => 接收回传 ${data.code}`)
})
},
  • 子组件二
this.pVue.$on('send2', (data, cb) => {
this.code2 = data.code
console.log(`表格组件 => 接收参数 ${data.code}`)
// 个人逻辑... 然后返回参数
cb({
code: data.code
})
})

发送并接收会参并根据会参再发送

  • 子组件一
send3() {
this.pVue.$emit('send3', {
code: this.code
}, (data, cb) => {
console.log(`按钮组件 => 接收回传 ${data.code}`)
cb({
code: data.code
})
})
}
  • 子组件二
this.pVue.$on('send3', (data, cb) => {
this.code3 = data.code
console.log(`表格组件 => 接收参数 ${data.code}`)
// 个人逻辑... 然后返回参数
cb({
code: data.code
}, () => {
this.code4 = data.code
console.log(`表格组件 => 再次接收参数 ${data.code}`)
})
})

所有代码

  • 父组件
<template>
<div class="home">
<button-list :p-vue="pVue" />
<div style="height: 20px" />
<table-list :p-vue="pVue" />
</div>
</template> <script>
import Vue from 'vue'
import ButtonList from './components/button-list'
import TableList from './components/table-list' export default {
name: 'Home',
data() {
return {
pVue: new Vue()
}
},
components: {
ButtonList,
TableList
}
}
</script> <style lang="scss" scoped>
.home {
height: 100%;
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
}
</style>
  • 子组件一
<template>
<div>
<el-input v-model="code" placeholder="过程在控制台" />
<el-row style="margin-top: 20px">
<el-button :disabled="code ===''" type="primary" @click="send1()">单项发送</el-button>
<el-button :disabled="code ===''" type="primary" @click="send2()">发送并接收回传</el-button>
<el-button :disabled="code ===''" type="primary" @click="send3()">发送接收并再发送</el-button>
</el-row>
</div>
</template> <script>
export default {
data() {
return {
code: ''
}
},
props: {
pVue: {
type: Object
}
},
methods: {
/**
* 单项发送
*/
send1() {
this.pVue.$emit('send1', {
code: this.code
})
},
/**
* 发送并接收回调
*/
send2() {
this.pVue.$emit('send2', {
code: this.code
}, (data) => {
console.log(`按钮组件 => 接收回传 ${data.code}`)
})
},
/**
* 发送接收并再发送
*/
send3() {
this.pVue.$emit('send3', {
code: this.code
}, (data, cb) => {
console.log(`按钮组件 => 接收回传 ${data.code}`)
cb({
code: data.code
})
})
}
}
}
</script>
  • 子组件二
<template>
<el-form label-width="80px">
<el-form-item label="参数1">
<el-input disabled v-model="code1"></el-input>
</el-form-item>
<el-form-item label="参数2">
<el-input disabled v-model="code2"></el-input>
</el-form-item>
<el-form-item label="参数3">
<el-input disabled v-model="code3"></el-input>
</el-form-item>
<el-form-item label="参数4">
<el-input disabled v-model="code4"></el-input>
</el-form-item>
</el-form>
</template> <script>
export default {
data() {
return {
code1: '',
code2: '',
code3: '',
code4: ''
}
},
props: {
pVue: {
type: Object
}
},
watch: {
code1(newVal, oldVal) {
console.log(oldVal)
console.log(newVal)
}
},
mounted() {
if (this.pVue) {
/**
* 单项接收
*/
this.pVue.$on('send1', data => {
this.code1 = data.code
console.log(`表格组件 => 接收参数 ${data.code}`)
this.pVue.boo = true
})
/**
* 发送并接收回调
*/
this.pVue.$on('send2', (data, cb) => {
this.code2 = data.code
console.log(`表格组件 => 接收参数 ${data.code}`)
// 个人逻辑... 然后返回参数
cb({
code: data.code
})
})
/**
* 发送接收并再发送
*/
this.pVue.$on('send3', (data, cb) => {
this.code3 = data.code
console.log(`表格组件 => 接收参数 ${data.code}`)
// 个人逻辑... 然后返回参数
cb({
code: data.code
}, () => {
this.code4 = data.code
console.log(`表格组件 => 再次接收参数 ${data.code}`)
})
})
}
}
}
</script>

2020年12月12日

Vue--子组件互相传值,子组件来回传值,传值反复横跳的更多相关文章

  1. 【vue】父组件主动调用子组件 /// 非父子组件传值

    一  父组件主动调用子组件: 注意:在父组件使用子组件的标签上注入ref属性,例如: <div id="home"> <v-header ref="he ...

  2. vue中子组件的拆分 父组件与子组件之间的传值

    vue是组件式开发,尽量独立出子组件 prop():父组件传值给子组件 $emit():子组件传值给父组件 子组件中的设置: 使用bind <template> : default-che ...

  3. EasyDSS RTMP流媒体服务器web前端:vue组件之间的传值,父组件向子组件传值

    之前接触最多的都是EasyNVR,主要针对的都是前端的一些问题.也有接触到一些easydss流媒体服务器. 前端方面的,EasyDSS流媒体服务器与EasyNVR有着根本的不同.EasyNVR使用的是 ...

  4. Vue父子,子父,非父子组件之间传值

    Vue组件基础 纯属随笔记录,具体详细教程,请查阅vue.js网站 子组件给父组件传值: <body> <div id="app"> <my-app& ...

  5. vue父组件调用子组件方法、父组件向子组件传值、子组件向父组件传值

      一.父组件调用子组件方法 父组件代码  parent.vue <template> <div> <button @click="parentFun" ...

  6. vue之provide和inject跨组件传递属性值失败(父组件向子组件传值的两种方式)

    简单介绍:当一个子组件需要用到父组件的父组件的某些参数.那么这个时候为了避免组件重复传参,使用vue的依赖注入是个不错的方法,直接在最外层组件设置一个provide,内部不管多少嵌套都可以直接取到最外 ...

  7. vue子组件如何向父组件传值

    子组件: <template> <div class="app"> <input @click="sendMsg" type=&q ...

  8. vue 父到子动态传值 子组件实时渲染

    近期项目中需要一个功能,根据选择不同的 团队片区 id 展示不同的数据,团队id 在父组件  数据在子组件中展示. 根据不同的团队 动态渲染数据总览. 父组件: <Cards ref=" ...

  9. vue组件之间的通信以及如何在父组件中调用子组件的方法和属性

    在Vue中组件实例之间的作用域是孤立的,以为不能直接在子组件上引用父组件的数据,同时父组件也不能直接使用子组件的数据 一.父组件利用props往子组件传输数据 父组件: <div> < ...

随机推荐

  1. arm64大服务器安装ubuntu18看不到安装界面

    前言 最近在使用arm的大服务器需要用到ubuntu相关的一些东西,在操作系统安装过程中遇到了一些问题 记录 华为鲲鹏服务器 这个默认安装centos的都很顺利,安装ubuntu18最新的,impi就 ...

  2. __all__有趣的属性

    python有趣的属性__all__可用于模块导入时限制,如:from module import *此时被导入模块若定义了__all__属性,则只有all内指定的属性.方法.类可被导入:若没定义,则 ...

  3. 想换4K显示器了?那你搞懂啥是4K了吗?

    前言 我们在科技资讯以及电脑显示器.数字电视等电子产品的宣传语中,经常能够看见4K的字样.最近,B站(哔哩哔哩)升级了HTML5播放器和视频云等相关服务,为广大用户提供了超高清(UHD: Ultra ...

  4. DOM XSS详解

    DOM XSS简介 DOM XSS与反射性XSS.存储型XSS的主要区别在于DOM XSS的XSS代码不需要服务端解析响应的直接参与,触发XSS的是浏览器端的DOM解析. DOM XSS复现 环境搭建 ...

  5. idea中运行tomcat不能访问8080主页问题

    问题 初次使用IntelliJ IDEA,但今天在运行项目启动Tomcat后,发现无法访问Tomcat首页,出现404错误:输入http://localhost:8080时无法访问Tomcat首页,但 ...

  6. java~通过springloaded实现热部署

    之前写过使用自定义的classLoader进行动态加载,热部署:它有很多弊端,我总结一下: 当前项目不能引用第三方包 当前项目必须使用反射的方式调用第三方包的方法 写死的一些路径 springload ...

  7. 深度分析:面试90%被问到的 Session、Cookie、Token,看完这篇你就掌握了!

    Cookie 和 Session HTTP 协议是一种无状态协议,即每次服务端接收到客户端的请求时,都是一个全新的请求,服务器并不知道客户端的历史请求记录:Session 和 Cookie 的主要目的 ...

  8. zabbix的搭建及操作(2)监控windows10及网络设备

    实验环境 配置完成的Server端 Web --详情点击 windows10 192.168.10.1 (与虚拟机同一Vmnet的IP地址)必须关闭防火墙 网络设备GNS 192.168.10.50 ...

  9. IDM下载器:站点抓取相关设置介绍

    Internet Download Manager(简称IDM)是一款十分好用资源下载器,它的站点抓取功能不仅可以下载被过滤器指定所需文件,例如一个站点的所有图片,或者一个站点的所有音频,也可以下载站 ...

  10. Pypi项目包发布

    前言 用过python的人肯定对pip安装不陌生,pip安装的包的来源都是在Pypi上.为了能随时能使用自己的包,所以尝试一下将自己的包发布到Pypi上. 步骤 一.准备项目 一.创建目录结构 二.准 ...