位置: IT常识 - 正文

vue子组件监听父组件数据变化并作出改变(亲测有效)(vue子组件监听父组件)

编辑:rootadmin
vue子组件监听父组件数据变化并作出改变(亲测有效) vue子组件监听父组件数据变化并作出改变(亲测有效)1. 问题1.1 封装组件时经常会遇到子组件需要根据父组件数据变化并执行对应的操作逻辑1.2 监听方法中加了deep、immediate 等参数监听数组/对象还是没有生效1.3 类型table组件需要根据父组件数据变化对表格数据进行更新1.4 根据数据动态渲染组件需实时监听父组件变化1.5 使用$refs 有些时候很难找到嵌套组件的ref2. 思路2.1 本文章主要的思路就是 provide / inject

推荐整理分享vue子组件监听父组件数据变化并作出改变(亲测有效)(vue子组件监听父组件),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue子组件监听父组件传过来的数组变化,vue子组件监听父组件变化watcheffect,vue子组件监听父组件,vue子组件监听父组件数据,vue子组件监听父组件事件,vue子组件监听父组件属性变化,vue子组件监听父组件传值变化,vue子组件监听父组件属性变化,内容如对您有帮助,希望把文章链接给更多的朋友!

2.2 创建父组件时,无论有多少层级的子组件都可以进行数据的相互依赖2.3 那么在子组件可以利用这些依赖对父组件数据进行监听3. 解决方法3.1 首先在父组件定义 provide,代码如下//父组件提供参数给子组件(响应式时需设置为对象)provide(){ return { superParams:this }},data(){ //定义几个参数return {test:{ testLevel1:{ testLevel2:'' } }, testList:[]}}3.2 子组件添加 inject,代码如下// 子组件:childrenComponent1inject: ['superParams'],watch:{ //监听数据变化 'superParams.test':{ immediate:true, // 将立即以表达式的当前值触发回调 handler:function (val,oldVal) { console.log("监听test对象"); console.log(val,oldVal); }, deep:true, }, 'superParams.test.testLevel1':{ immediate:true, // 将立即以表达式的当前值触发回调 handler:function (val,oldVal) { console.log("监听testLevel1属性"); console.log(val,oldVal); }, deep:true, }, 'superParams.test.testLevel1.testLevel2':{ immediate:true, // 将立即以表达式的当前值触发回调 handler:function (val,oldVal) { console.log("监听testLevel1属性"); console.log(val,oldVal); }, deep:true, }, 'superParams.testList':{ immediate:true, // 将立即以表达式的当前值触发回调 handler:function (val,oldVal) { console.log("监听testList数组"); console.log(val,oldVal); }, deep:true, }}3.3 另外一个子组件触发父组件数据变化(同/不同层级都可以触发)// 子组件:childrenComponent2inject: ['superParams'],mounted(){ this.superParams.test.testLevel1.testLevel2 = 'testLevel22'; this.superParams.testList.push({test:'test'})}举例一(子组件按顺序展示):先显示childrenComponent2 ,再到childrenComponent1,(下图的数据在childrenComponent1展示后输出)结果如图所示

举例二(子组件都展示, 在父组件或其他地方触发数据更新)vue子组件监听父组件数据变化并作出改变(亲测有效)(vue子组件监听父组件)

在父组件添加一个按钮点击触发方法代码如下

updateText(){ console.log("Text数据更新"); this.test.testLevel1.testLevel2 = 'testLevel22'; this.testList.push({test:'test'})}

结果如下图所示

注意当前组件监听方法数据作出了改变,但组件却没有更新,这时需在组件本身找更新原因组件显示时会对监听方法进行初始化对于对象存在多层的监听问题,可监听整个对象对于数组会不会存在漏监听的情况,经测试调用数组的pop、push、shift、unshift、splice、sort、reverse等方法时是可以监听到数组的变化immediate、deep 要了解补充

针对注意点1,以el-input-number(element ui)组件为例

<el-input-number v-model="item.max" @change="handleChange" :min="0" :key="Math.random()" :max="superParams.max"></el-input-number>

在没有加上 :key=“Math.random()” 前组件并没有随着父组件数据(superParams.max)变化

加上后可根据父组件数据动态改变

父组件改变参数值代码如下图所示

'formData.isTrue':function (val,oldVal) { if(val){ this.max = 100; }else { this.max = 50; }},

并不是所有组件都能用 :key=“Math.random()” ,某些组件使用后会出现卡顿或者无法输入值

本文链接地址:https://www.jiuchutong.com/zhishi/298445.html 转载请保留说明!

上一篇:微信小程序项目实例——我有一支画笔(画画)(微信小程序项目中app.js文件是全局样式文件)

下一篇:使用vite 搭建vue 3的项目(vite搭建vue3)

  • 自行申报是什么征收方式
  • 公司有残疾人需要交税吗
  • 收到预付款的发票怎么写摘要
  • 销售自产自销的产品要交税吗?
  • 用于文化活动费用的科目
  • 业务招待费进项税额需要转出吗
  • 所得税需要结转嘛
  • 住宿费增值税怎么算
  • 2017房地产行业流动比率均值
  • 软件企业产品如何销售
  • 净资产收益率计算公式用期末净资产
  • 销售成本结转账务处理
  • 销售支付运费属什么科目
  • 上年度退回来的所得税,怎么做分录
  • 增值税如何计提和结转
  • 城市维护建设税属于什么税种
  • 金融企业哪些呆账损失可以在税前扣除?
  • 如何准确区分不动产租赁和仓储服务?
  • 销售电梯并安装如何缴纳增值税
  • 库存商品适用于什么账簿
  • 增值税发票过期未抵扣怎么办
  • 自产自销的茶叶要交增值税吗
  • linux怎么操作
  • php比较大小的函数
  • msoobe.exe是什么
  • 刷票系统能看出来吗
  • 开发商延期交房违法吗
  • 圆顶亭效果图
  • antdesign vue pro
  • php日期差数
  • php 文件上传类型限制
  • laravel框架关键技术解析
  • 企业的银行账户按用途分不包括的是
  • 超级鸽卫星
  • 基于web的疫情防控方案
  • vue修饰词
  • mail命令详解
  • 直播服务费的开票大类
  • 举报民间借贷利息收入所得税
  • 电费发票查不到
  • 社保的残保金的用途
  • java 读写锁 map
  • 私募基金成立备案流程
  • 视同销售的增值税怎么申报
  • 高速费发票可以抵税吗
  • 用房子贷款印花税怎么算
  • 拆迁补偿如何进行
  • 物业费的会计处理
  • 本年利润的会计科目
  • 一般纳税人销售使用过的固定资产
  • 平均增长率计算公式怎么算
  • 怎样算小公司
  • 出纳建账账户名称怎么写
  • sqlserver2005网络配置里没有东西
  • 排序mysql
  • window10安装mysql5.7
  • centOS7安装MySQL数据库
  • sql实现分页查询语句
  • 联想yoga升级win11
  • xp怎么把ie浏览器放到桌面
  • fedora怎么联网
  • bios怎么调高性能
  • ubuntu 20.04桌面
  • gws.exe是啥
  • SFC无需光盘出马,硬盘搞定
  • win7 0x80070002处理方法
  • win10 64位系统提示0x80070643错误代码的解决方法
  • js格式化日期yyyy-mm-dd hh:mm:ss
  • 安卓演示模式有什么用
  • unity导入工程根本运行不了
  • ubuntu20.04 python
  • js设置标签内容
  • android电池优化设置
  • 详解jQuery中的empty、remove和detach
  • 利息收入通过什么科目核算
  • 金税盘软件怎么打开
  • 吸收合并是什么意思
  • 济宁市税务局官网名称
  • 江苏省纳税信息查询
  • 临沂市2020年居民燃气价格
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设