页面大量输入框性能优化

在开发中遇到性能问题,60行20列的表格导致页面加载慢,每个格子都是输入框,总计1200个。为解决这个问题,采取了一个策略,用span模拟输入框,在点击时动态切换为真实输入框并聚焦,失焦后恢复为span,有效减少了DOM渲染的开销,提高了页面性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遇到一个性能问题是这样的:

我有一个表格,表格里面的每一个格子都可以编辑,开始我没多想直接就撸,反正就是一个输入框。

然后我本地开发时问题不大,因为行列都是动态的,本地数据也不多,电脑性能也还行

哐哐上线后,客户炸了,怎么我进入这个页面还好好的,点编辑之后要七八秒才反应过来

然后表格数据量大概是60多行20多列,也就是当前页面存在1200个输入框左右

开始也是一脸懵逼,然后再本地再调试相同数据量的输入框,大概渲染时间也要3-4秒,完犊子

原因:不同的dom渲染消耗的内存是不一样的,很明显一个input标签就要比一个span标签消耗多得多

然后我就写了这个组件:
做一个假的输入框,实际它只是一个span,只是看起来像一个输入框,当我点击它的时候,它变成一个输入框并且聚焦在当前这个输入框上,也就是用户感知是一个输入框,实际它偷偷切换了,并且在失焦的时候再把它变成span

size和elementUi的是一样的,样式也是抄elementUi的
上组件代码

<template>
  <div class="jm-fakeInput">
    <span v-if="!showInput" @click="spanclick" class="fakeInput" :class="{'mini':size==='mini','small':size==='smal
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值