【ElementUI】el-table可编辑/输入框 卡顿性能问题解决案

大家好,我是九幡。

在这篇文章我将为大家分享一个优化可编辑el-table性能问题的方案。

目录

问题背景

原因分析

解决思路

样例代码

页面效果

方案的优缺点


问题背景

用el-table配合el-input直接渲染可编辑行,在数据量大的情况下,会出现输入卡顿的问题。

 

原因分析

1. el-input组件实例数量过多。

2. el-input的v-model在表单输入时频繁触发更新事件。

 

解决思路

1. 用原生input替换el-input,以减少el-input组件实例。并在原生input上应用el-input的样式,使前者后者外观一致。

2. 在v-model指令上追加.lazy修饰符,使实例数据仅在失去焦点时更新,减少触发次数。

 

样例代码

 

页面效果

 

此时光标进入输入框,执行输入动作,画面依然能获得快速、良好的反馈:

 

方案的优缺点

优点:

1. 解决了可编辑el-table在数据量大的情况下的性能问题。

2. 与网上我能够搜索到的大部分解决方案不同,没有额外引入第三方插件。

3. 实现方式简单、快速、方便。

 

缺点:

没有使用el-input组件,不能直接使用el-input提供的功能。

 

以上就是本文的全部内容啦,本人能力有限,如果记述有误,还请您留言指出,感谢谅解和支持。

如果您有更好的想法和建议,欢迎留言评论!如果这篇文章有帮助到您,希望您能为本篇文章点个赞!

<div> <el-table :data="fetchtechnicalsourceInfo" > <!-- <el-table :data="requirementinfo.visitexcelData" > --> <!-- <el-table :data="sourcetable" style="width: 1000px" header-cell-style="{ height: '1000px' }" row-style="{ height: '1000px' }" > --> <el-table-column prop="name" label="姓名" align="center" min-width="10%"></el-table-column> <el-table-column prop="school" label="科研院所" align="center" min-width="15%"></el-table-column> <el-table-column prop="conclusion" label="交流结论" align="center" min-width="45%"></el-table-column> <el-table-column prop="iscoo" label="是否合作" align="center" min-width="10%"></el-table-column> <el-table-column label="操作" align="center" min-width="15%"> <!-- <template slot-scope="{row}"> --> <!-- <el-button size="small" @click="editItem(row)">编辑</el-button> <el-button size="small" type="danger" @click="deleteItem(row.id)">删除</el-button> --> <!-- <el-button size="small" @click="viewItem(row)">查看</el-button> </template> --> <template slot-scope="scope"> <el-button type="primary" size="mini" icon="el-icon-user" style="margin-left:10px" @click="viewItem(scope.row)" slot="reference">查看主页</el-button> </template> </el-table-column> </el-table> </div> computed: { fetchtechnicalsourceInfo() { try { const data = this.requirementinfo.technicalsource; // console.log('fetchtechnicalsourceInfo返回的教师信息3:', this.requirementinfo); if (!data) return []; // 拆分数据 const items = data.split(';'); // 使用中文分号分割 const parsedsource = items.map(item => { const [name, school, conclusion,iscoo] = item.split('-'); return { name, school,conclusion, iscoo }; }); this.technicalsourcetable = parsedsource; return parsedsource; } catch (error) { console.error('获取寻源信息失败', error); return []; } }, }, 后续想通过按钮点击新增一行el-table的信息怎么实现
08-29
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值