页面输入框输入数据后,页面出现自动回到顶部的问题(已解决)

博客探讨了在使用ElementUI的el-table组件时遇到的问题:当修改表格数据并希望通过页面重新渲染更新视图,却导致页面滚动条返回顶部。问题源于使用`key=Math.random()`强制更新,解决方案是利用`this.$set()`方法修改数组数据,避免了不必要的页面跳动。此博文详细分析了问题原因及最佳实践。
摘要由CSDN通过智能技术生成

问题再现效果:

 问题描述:当前页面是一个带有滚动条的页面,表格是使用elementUI中的表格el-table组件封装的,页面输入框输入数据后,页面自动回到了顶部,确实难受;

问题原因:表格中数据是可以更改的,之前是直接用 this.tableData[index].classTime = 10; 改变的数组数据,数据是改变了,但是页面没有重新渲染,为了达到渲染效果在封装的表格组件上加了一个属性  :key="Math.random()"   , 这样倒是页面重新渲染了,但也导致了页面自动回到顶部的问题,现在改成使用这种方式改变数组数据: this.$set(this.tableData[this.index], 'orderTimes', num);  就可以了,表格组件也不需要加 :key="Math.random()" 了;

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值