首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >大型Grid.js响应表

大型Grid.js响应表
EN

Stack Overflow用户
提问于 2020-12-29 00:07:16
回答 1查看 312关注 0票数 0

在可调整大小的容器中呈现grid.js表的最佳方法是什么?

如果我不设置网格的高度配置对象,表的大小会超过它的容器,并且我无法访问表末尾的溢出栏。

代码语言:javascript
复制
grid = new gridjs.Grid({
  columns: [/*A lot of column*/],
  fixedHeader: true,
  width: document.getElementById("MY_CONTAINER_ID").clientWidth,
  height: document.getElementById("MY_CONTAINER_ID").clientHeight,
  data: () => {
   return new Promise(resolve => {
    setTimeout(() =>
      resolve([/*A lot of rows*/]), 2000);
    });
  }
}).render(document.getElementById("MY_CONTAINER_ID"));

在可调整大小的div中,我们可以使用.updateConfig()方法设置高度并重新呈现所有数据,但这是无稽之谈(如果数据集非常大,更是如此)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-09-17 12:42:46

为了解决这个问题,我使用了ResizeObserver()

我在gridjs.Grid配置接口之外设置了"gridjs- wrapper“的高度和with,并使用连接到容器的resize侦听器的值动态调整包装器的大小。

代码语言:javascript
复制
grid = new gridjs.Grid({
  columns: [/*A lot of column*/],
  fixedHeader: true,
  width: document.getElementById("MY_CONTAINER_ID").clientWidth,
  height: document.getElementById("MY_CONTAINER_ID").clientHeight,
  data: () => {
   return new Promise(resolve => {
    setTimeout(() =>
      resolve([/*A lot of rows*/]), 2000);
    });
  }
}).render(document.getElementById("MY_CONTAINER_ID"));
setGridSize();
new ResizeObserver(() => setGridSize()).observe(document.getElementById("MY_CONTAINER_ID"));
        
function setGridSize(){
  var mywrapper = document.getElementsByClassName("gridjs-wrapper");
  var height = document.getElementById("MY_CONTAINER_ID").clientHeight;
  var width = document.getElementById("MY_CONTAINER_ID").clientWidth;
  mywrapper[0].style.height = height.toString() + "px";
  mywrapper[0].style.width = widht.toString() + "px";
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65480502

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档