ant-design-vue table 表格组件错位解决

table组件错位问题。


image.png

table组件错位,不管是用element-ui的table组件,还是ant的table组件,只要使用了列的fixed属性,在第一次进入页面时就会出现。

原因查找

经检查dom发现使用fixed后,table组件实际由3个table组成,左边一个,中间一个,右边一个


image.png

。如果中间表格有某一列的内容有换行或者特殊内容等,


image.png

,这会导致表格实际高度比没有特殊内容要高。三个表格初次渲染的时候,由于中间表格高度还在变化,左右两边的表格读取到的高度不准确。导致错位。

错位消失机制

经反复测试发现只要触发table表格页面重排,错位就消失了,例如勾选一下选择列,点击刷新按钮重新调下接口重新加载数据,浏览器窗口尺寸编号等。这是因为做这些操作会触发浏览器页面元素重排,重排会导致浏览器重新对页面布局,尺寸进行计算,这时候中间的表格高度也确定了,左右两边重新获取了准确的高度。

解决思路

根据反复测试表格消失的原因,解决思路之一就是如何在代码里面触发表格重排。

试验一

在表格初次渲染完成以后,代码里面用splice手动替换第一条数据


image.png

该方法经实验可行。但是经反复不断测试,还是有出现错位的可能。总体来说还是表格渲染比较复杂。分成3个表格后,三个表格是独立渲染的,接收一次数据,中间的表格可能会执行多次,最后一次执行后,表格高度还是会发生变化,而两边的表格却并没有再变化。别问我是如何知道的,浏览器控制台打印三个表格的高度看数据看到的。

试验二

根据方法一试验的结果和获取表格高度数据的分析,进行第二次试验。这次主要改变点就是要不断监听三个表格高度变化情况,确认三个表格高度一致后才定制。准确说是两边的高度和中间的表格高度误差在一个像素以内。这个误差值也是测试观察表格高度数据得出的结论,并且误差在一个之内,肉眼基本看不出错位。
关键代码如下,这段代码放表格渲染的render函数中:

    let tableId = ""
    if (props.dataSource.length) {
      const firstDataIndex = this.oldColumns[0].dataIndex.replace(/\./g, "")
      tableId = `tableId${firstDataIndex}${props.dataSource[0][props.rowKey]}`
      this.tableId = tableId
      this.$nextTick(()=>{
        // 解决错位问题,定时检查高度,触发页面重排
        this.updateTableHeight(() => props.dataSource.splice(0, 1, props.dataSource[0]))
      })
    }

在methods中定义updateTableHeight函数。经测试,表格render执行5次后,高度已基本稳定。这里使用定时器监听表格高度变化,当高度误差大于1px时,执行一次重排触发。

methods:{
    /**
     * 更新表格高度
     * @param callback
     */
    updateTableHeight(callback) {
      clearInterval(this.interval)
      // console.log(this.tableId)
      const tableWrap = document.getElementById(this.tableId)
      // console.log(tableWrap)
      if(!tableWrap){
        return
      }
      const tableMiddle = tableWrap.querySelector(".ant-table-fixed")
      if (!tableMiddle) {
        return
      }
      const intervalSetHeight = () => {
        const tableRight = tableWrap.querySelector(".ant-table-fixed-right")
        const tableLeft = tableWrap.querySelector(".ant-table-fixed-left")
        clearInterval(this.interval)
        this.interval = setInterval(()=>{
          if(this.renderNum > 5){
            clearInterval(this.interval)
            return
          }
          // console.log(tableRight.clientHeight)
          const middleHeight = tableMiddle.clientHeight
          const leftHeight = tableLeft ? tableLeft.clientHeight : -1
          const rightHeight = tableRight ? tableRight.clientHeight : -1
          if (leftHeight !== -1) {
            if (middleHeight - leftHeight > 1) {
              callback()
            }
          } else if (rightHeight !== -1) {
            if (middleHeight - rightHeight > 1) {
              callback()
            }
          }
          this.renderNum++
        },100)
      }
      intervalSetHeight()
    }
}

解决的背后

以上就是解决ant-design-vue 表格错位的思路。也可以用于element-ui。但是这种思路并不是很好。各位大神,有好的思路吗?

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,816评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,729评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,300评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,780评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,890评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,084评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,151评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,912评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,355评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,666评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,809评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,504评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,150评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,121评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,628评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,724评论 2 351

推荐阅读更多精彩内容