IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> ant-design-vue table 表格组件错位解决 -> 正文阅读

[JavaScript知识库]ant-design-vue table 表格组件错位解决

table组件错位问题。
在这里插入图片描述

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

原因查找

经检查dom发现使用fixed后,table组件实际由3个table组成,左边一个,中间一个,右边一个
在这里插入图片描述

。如果中间表格有某一列的内容有换行或者特殊内容等,
在这里插入图片描述

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

错位消失机制

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

解决思路

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

试验一

在表格初次渲染完成以后,代码里面用splice手动替换第一条数据
在这里插入图片描述
该方法经实验可行。但是经反复不断测试,还是有出现错位的可能。总体来说还是表格渲染比较复杂。分成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。但是这种思路并不是很好。各位大神,有好的思路吗?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-24 09:20:29  更:2022-04-24 09:21:53 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 1:13:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码