- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经使用以下示例作为指南构建了一个 html 表,但是我一直无法弄清楚如何使头部固定,以便在用户滚动时它仍然可见:
https://jsfiddle.net/thatOneGuy/u5bvwh8m/16/
我试过用CSS来控制
.resizable{overflow-y: auto; position: sticky; height: 750px;}
我也尝试过向头部添加自定义样式,但这会破坏调整大小:
table thead tr{
display:block;
}
table th,table td{
width:100px;//fixed width
}
table tbody{
display:block;
height:200px;
overflow:auto;//set tbody to auto
}
非常感谢任何帮助。
最佳答案
试试这个
thead th{
position: sticky !important;
top: 0;
background-color: white;
}
并从 table
标签中移除 resizable
类并将其放入 thead
和 tbody
标签
<table id="tableId" >
<thead class="resizable">
...
<tbody class="resizable">
//var tables = document.getElementsByClassName('flexiCol');
var tables = document.getElementsByClassName('resizable');
for (var i = 0; i < tables.length; i++) {
resizableGrid(tables[i]);
}
function resizableGrid(table) {
var row = table.getElementsByTagName('tr')[0],
cols = row ? row.children : undefined;
if (!cols) return;
table.style.overflow = 'hidden';
var tableHeight = table.offsetHeight;
for (var i = 0; i < cols.length; i++) {
var div = createDiv(tableHeight);
cols[i].appendChild(div);
cols[i].style.position = 'relative';
setListeners(div);
}
function setListeners(div) {
var pageX, curCol, nxtCol, curColWidth, nxtColWidth, tableWidth;
div.addEventListener('mousedown', function(e) {
tableWidth = document.getElementById('tableId').offsetWidth;
curCol = e.target.parentElement;
nxtCol = curCol.nextElementSibling;
pageX = e.pageX;
var padding = paddingDiff(curCol);
curColWidth = curCol.offsetWidth - padding;
// if (nxtCol)
//nxtColWidth = nxtCol.offsetWidth - padding;
});
div.addEventListener('mouseover', function(e) {
e.target.style.borderRight = '2px solid #0000ff';
})
div.addEventListener('mouseout', function(e) {
e.target.style.borderRight = '';
})
document.addEventListener('mousemove', function(e) {
if (curCol) {
var diffX = e.pageX - pageX;
// if (nxtCol)
//nxtCol.style.width = (nxtColWidth - (diffX)) + 'px';
curCol.style.width = (curColWidth + diffX) + 'px';
console.log(curCol.style.width)
console.log(tableWidth)
document.getElementById('tableId').style.width = tableWidth + diffX + "px"
}
});
document.addEventListener('mouseup', function(e) {
curCol = undefined;
nxtCol = undefined;
pageX = undefined;
nxtColWidth = undefined;
curColWidth = undefined
});
}
function createDiv(height) {
var div = document.createElement('div');
div.style.top = 0;
div.style.right = 0;
div.style.width = '5px';
div.style.position = 'absolute';
div.style.cursor = 'col-resize';
div.style.userSelect = 'none';
div.style.height = height + 'px';
return div;
}
function paddingDiff(col) {
if (getStyleVal(col, 'box-sizing') == 'border-box') {
return 0;
}
var padLeft = getStyleVal(col, 'padding-left');
var padRight = getStyleVal(col, 'padding-right');
return (parseInt(padLeft) + parseInt(padRight));
}
function getStyleVal(elm, css) {
return (window.getComputedStyle(elm, null).getPropertyValue(css))
}
};
* {
box-sizing: border-box;
}
table {
border-collapse: collapse;
}
td,
th {
padding: 5px 15px;
text-align: left;
}
table,
th,
td {
border: 1px solid #000;
}
thead th {
position: sticky !important;
top: 0;
background-color: white;
}
<table id="tableId" >
<thead class="resizable">
<tr>
<th><input type="checkbox" /></th>
<th>Size</th>
<th>File</th>
</tr>
</thead>
<tbody class="resizable">
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
<tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr><tr>
<td><input type="checkbox" /></td>
<td>10Mb</td>
<td>C:\Usabc.txt</td>
</tr>
</tbody>
</table>
关于jquery - 修复了可调整大小的 HTML 表格的标题,包括自动水平滚动溢出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66667061/
我目前正在研究一个项目欧拉问题(www.projecteuler.net),但遇到了一个绊脚石。其中一个问题提供了一个 20x20 的数字网格,并要求直线上 4 个数字的最大乘积。这条线可以是水平的、
我有两个表,我需要从每个表中选择一列。 这必须在单个查询中完成。 好消息是这两列以正确的方式排序,并且它们都包含相同数量的行。 现在,我知道我可以通过 rowid 加入两个表,但它很慢,因为它必须进行
我想在我的 iPad 应用程序中实现一个布局,该布局具有一个可左右滚动而不是上下滚动的合适 View : 所以而不是 第 1 行第 2 行第 3 行(垂直滚动)这将是 :第 1 行、第 2 行、第 3
我有五个尺寸的图像:600x30、600x30、600x30、600x30、810x30。它们的名称分别是:0.png、1.png、2.png、3.png、4.png。 如何使用 ImageMagic
我正在寻找一个选项来滚动多个列表(水平),如附件中的图片所示。您可以向左或向右滑动以进入下一个 ListView 。顶部应该有一些按钮可以单击或滚动 我尝试将 ListViews 放入类似此代码的内容
这些值之间是否存在数学关系?如果我知道 hFOV 和 vFOV,我可以计算对角 FOV 而不涉及焦距等其他值吗? 我的第一个想法是使用毕达哥拉斯定理,但也许这是错误的。 最佳答案 感兴趣的物理量是传感
我正在尝试在 game_width=640 和 game_height=480 的窗口内绘制网格。网格单元的数量是预定义的。我想在水平和垂直方向上均匀分布单元格。 void GamePaint(HDC
你好,我已经发布了我的 iphone 应用程序 Micro-Pitch,现在正在将它移植到 android 上。我不知道如何在 ScrollView 中画线,想知道我做错了什么。 这是我的 Scrol
如果您访问我的网站:www.ryancoughlin.com - 如果您在页面右侧看到 Google、Yahoo 等 RSS 按钮。我试图让它们均匀对齐,它们的图像高度都相同,我一直试图让它们均匀对齐
我想将此 Material 水平居中: 最佳答案 将 text-align:center 添加到您的 anchor 。我假设您的 zoom1 具有 display
我正在努力做到这一点,以便我的旋转木马可以与其他文本共享一个水平行,但由于某种原因它无法正常工作,当它设置为 40% 时它占据了 100% 的宽度。 我将在下面发布代码和屏幕截图。 在上图中,它显示了
问题来了。我正在尝试放置一些 彼此相邻的元素。 div 的宽度s 未指定,取决于它们的内容。我正在使用下面的 CSS 代码来定位 彼此相邻: #div{ height: 50px; f
我正在尝试使用这样的 Bootstrap 并排打印表格 但是当我尝试打印预览时,我得到了这个 我的代码如下。我尝试了所有可能的解决方案,但我不知道为什么我无法打印我看到的页面。请指导我解决这个问题。
我想知道是否可以在背景中使用两种不同的颜色,并通过 Bootstrap 在每一侧扩展 100%。 这是我的意思的截图, 左侧为红色,右侧为深色,为更大的屏幕放大 100%。有什么简单的解决方案吗? 最
我正在尝试制作一个包含所有事件的滚动触发的整个网站。我只需要帮助来实现这种效果: 我有一个网站,其中包含一些填满所有视口(viewport)的 div,我希望用户能够向下滚动到一个命名的 div,然后
我的代码是 Show All Show Valid Show Pending Save Clear Download As CSV 我希望那些输入日期和按钮在 class="buttons" di
我在玩这个想法: 在这个 block 中我有 2 作为按钮和 并尝试了 float荷兰国际集团他们让他们粘在一起。实现这种效果的主要思想是操纵 ul 的宽度/显示状态。或者只是菜单部分。 Log
这个问题在这里已经有了答案: How can I horizontally center an element? (134 个回答) 关闭 4 年前。
我遇到了一个 CSS 问题,需要帮助。我在目录中有许多不同大小的图像,我正在动态列出它们以显示以下 View :(我仅显示两个图像作为示例) 这是我的 HTML:
这个问题在这里已经有了答案: 关闭 9 年前。 Possible Duplicate: How can I make a horizontal ListView in Android? 我已经多次使
我是一名优秀的程序员,十分优秀!