Element-ui的table中使用fixed后出现行混乱情况的解决

 更新时间:2023年10月20日 08:45:17   作者:尼古拉斯二嘎  
这篇文章主要介绍了Element-ui的table中使用fixed后出现行混乱情况的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Element-ui的table中使用fixed后出现行混乱

话不多说,先看看问题是什么

我们看到table左侧fixed的区域并没有延伸到表格底部,之前在用户拖拽表格时添加了方法this.$refs.headGroupTable.doLayout()来重置表格(headGroupTable是自定义组件名称,学过vue的都懂),但是在数据拿到后使用此方法并不能解决以上问题

解决方法

其实解决方法也很简单,我们打开浏览器看到fiexed的表格区域样式的高度是固定的px,这是我只需要添加一下代码即可

.el-table__fixed {
  height: 100%!important;
}

其实这里我想告诉大家,解决问题的方法不难找出,很多种方案都可实现,比如还可以使用jq、元素js等等都可以解决以上问题,当然我只是把最简单暴力的贴出来了,温馨提示下,这个样式不建议全局修改,你可以写成局部样式,部分组件生效

使用element-ui table组件 fixed 布局错位 问题原因解决

问题

使用element-ui table表格布局,头尾列fiexd时,在chrome,火狐,edg浏览器上布局正常,但是在国产浏览器,qq浏览器,UC浏览器,360浏览器上布局错乱。

原因

因为chrome正常,所以怀疑是国产浏览器的chrome内核版本问题,就查看了一下,qq浏览器是70,uc浏览器55,360是65,而edg浏览器和chrome浏览器内核版本均是92。

造成的直接原因其实已经找到了,就是国产浏览器chrome内核版本低,而element-ui在低版本chrome内核上没有做兼容。

解决

直接原因知道了,但是怎么解决?

习惯性百度了一下,果然有很多网友也遇到同样的问题,提供的方案也多种,其中说的最多的是调用element-ui table组件的doLayout方法,重新刷新布局。

然并卵,试了网友的多种方法均无效!

那只能尝试另辟蹊径。于是查看了其他页面,发现项目里面的用户列表页面同样有换行,但是没有错乱。

既然有不一致,那就对比两个页面,发现其实没多大差异,所以智能来笨办法。

将有问题的列表的el-table-column注释,看页面反应。

首先将使用了 的el-table-column注释,结果返现,当吧含有组件file-view-list (一个文件预览组件) 的el-table-column注释后,页面竟然正常了!!

那就是file-view-list组件有问题,于是找到file-view-list组件里面,注释里面的样式,后面终于找到了影响页面布局的css,竟然是一个多行省略样式,scss的混合。

//多行省略
@mixin textMultiLineEllipsis($clamp:1){
  overflow : hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: $clamp;
  -webkit-box-orient: vertical;
}

具体为何影响的深层次原因目前尚不清楚,但是后面换了种写法就好了,换成单行省略的写法

//省略号
@mixin textEllipsis ($width) {
  max-width: $width;
  overflow: hidden;
  -ms-text-overflow: ellipsis;
  text-overflow: ellipsis;
  white-space: nowrap;
}

不过深层次原因还没有找到。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Vue实现Google第三方登录的示例代码

    Vue实现Google第三方登录的示例代码

    本文记录作者在vue项目中使用到Google第三方登录,查询到的资料文档也不详细,故此把自己所遇到的坑及问题详细的记录下来。
    2021-07-07
  • elementUI弹窗里的表单重置不生效问题解决

    elementUI弹窗里的表单重置不生效问题解决

    本文主要介绍了elementUI弹窗里的表单重置不生效问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • 在vue+element-plus中无法同时使用v-for和v-if的问题及解决方法

    在vue+element-plus中无法同时使用v-for和v-if的问题及解决方法

    由于路由中存在不需要遍历的数据所以像用v-if来过滤,但是报错,百度说vue不能同时使用v-if和v-for,今天小编给大家分享解决方式,感兴趣的朋友跟随小编一起看看吧
    2023-07-07
  • Vue之mixin混入详解

    Vue之mixin混入详解

    这篇文章主要为大家介绍了Vue之mixin混入,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-11-11
  • vue安装vue-router出错问题及解决

    vue安装vue-router出错问题及解决

    这篇文章主要介绍了vue安装vue-router出错问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

    Vue项目的甘特图组件之dhtmlx-gantt使用教程和实现效果展示(推荐)

    文章介绍了如何使用dhtmlx-gantt组件来实现公司的甘特图需求,并提供了一个简单的Vue组件示例,文章还分享了一些配置项,如格式化表头日期、设置甘特图尺寸、启用只读模式、设置表格列等,感兴趣的朋友一起看看吧
    2025-02-02
  • Vue3实现折叠面板组件的示例代码

    Vue3实现折叠面板组件的示例代码

    折叠面板大家都不陌生,很多时候需要实现一些复杂的交互,就会用到它,简洁直观还美观,下面就跟随小编一起学习一下如果使用Vue3实现折叠面板组件吧
    2024-01-01
  • Vue入口文件index.html缓存的问题及解决

    Vue入口文件index.html缓存的问题及解决

    这篇文章主要介绍了Vue入口文件index.html缓存的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • vue elementUI实现拖拽流程图效果

    vue elementUI实现拖拽流程图效果

    这篇文章主要为大家详细介绍了如何通过vue elementUI实现拖拽流程图效果,不引入插件,纯手写实现,感兴趣的小伙伴可以跟随小编一起学习一下
    2025-01-01
  • FastApi+Vue+LayUI实现前后端分离的示例代码

    FastApi+Vue+LayUI实现前后端分离的示例代码

    本文主要介绍了FastApi+Vue+LayUI实现前后端分离的示例代码,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11

最新评论