问题:
- 在el-table-column里使用v-if,表格错乱或者无效
- 因为解决问题1导致的表头闪烁
解决方案
- 问题1:
我在
el-table-column里使用了template标签来进行包裹,里面通过v-if判断是否显示,但是会出现表格错乱或者不同步的问题。
<el-table-column label="名字" prop="name">
<template slot-scope="{ row }">
<div class="flexCenter" :title="row.server_filename">
<el-button v-if="row.isflag" @click="handleName"> {{row.name }}</el-button>
<el-button v-else @click="handleName"> {{ row.name }}</el-button>
</div>
</template>
</el-table-column>
解决方法:
必须要在
el-table-column里加入:key="Math.random()",通过生成随机数来刷新表格
- 问题2:
由于我在
el-table-column里加入了:key="Math.random()",会导致表头部分闪烁的问题
解决方法:
element-ui中的dolayout函数可以很好的解决表头闪烁的问题
beforeUpdate () {
this.$nextTick(() => {
this.$refs.file_table.doLayout()
})
},

本文探讨了在Element UI的el-table-column中使用v-if时出现的表格错乱问题及其解决方法,并介绍了如何避免表头闪烁现象。

2703

被折叠的 条评论
为什么被折叠?



