Make table headers sticky

05/08/2025, 13:00:14

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

Advertisement:

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

Advertisement:

// ==UserScript==
// @name        Make table headers sticky
// @namespace   Violentmonkey Scripts
// @match       https://*/wiki/*
// @match       https://techlore.tech/*
// @match       https://wiki.*/*
// @match       https://*freie-messenger*/*
// @grant       none
// @version     1.1
// @author      SHA
// @license     GNU GPLv3
// @description 05/08/2025, 13:00:14
// ==/UserScript==

// TODO: use jQuery and $(...).floatThead() instead because "display: sticky" doesn't work with "overflow-x: auto".

window.addEventListener("load", (event) => {

  setTimeout(() => {
    const tables = document.querySelectorAll("table:not(.infobox):not(.sidebar)"); // exclude fact sheets on wikipedia
    tables.forEach(table => {
      table.style.display = "table";
      const header = table.querySelector("tr:first-of-type");
      header.style.position = "sticky";
      header.style.top = "0";
      header.style.zIndex = "10000";
      const rowHeaders = table.querySelectorAll("tbody th");
      rowHeaders.forEach(th => {
        th.style.position = "sticky";
        th.style.left = "0";
        th.style.zIndex = "10000";
      });
    });

    // for https://techlore.tech/vpn/
    const grids = document.querySelectorAll("*[role=grid]");
    grids.forEach(grid => {
      grid.style.display = "initial";
      const header = grid.querySelector("*[role=rowgroup]:first-of-type");
      header.style.position = "sticky";
      header.style.top = "0";
      header.style.zIndex = "10000";
    });
  }, 500);
});