← 全部示例

JavaScript 效率 news.ycombinator.com

Hacker News:j/k 键盘导航

使用 j 和 k 键在评论和帖子之间切换,并高亮当前项目。

可复制的代码

// Navigate between comments with the j and k keys
(function () {
  const items = Array.prototype.slice.call(
    document.querySelectorAll('.comtr, .athing')
  );
  if (!items.length) { return; }
  let idx = -1;
  function focus(n) {
    if (n < 0 || n >= items.length) { return; }
    idx = n;
    const el = items[idx];
    el.scrollIntoView({ block: 'center', behavior: 'smooth' });
    items.forEach(function (i) { i.style.outline = ''; });
    el.style.outline = '2px solid #ff6600';
  }
  document.addEventListener('keydown', function (e) {
    const t = e.target.tagName;
    if (t === 'INPUT' || t === 'TEXTAREA') { return; }
    if (e.key === 'j') { focus(idx + 1); }
    else if (e.key === 'k') { focus(idx - 1); }
  });
})();

如何使用此示例

  1. 用上方按钮复制代码。
  2. 安装 JustZix(2 分钟),在目标页面打开扩展。
  3. 添加一条匹配该页面的新规则。
  4. 将代码粘贴到规则的 JavaScript 面板并保存 — 每次访问页面时都会运行。

为此示例评分

暂无评分 — 成为第一个。

此示例有效吗?

没有可粘贴的地方,代码片段毫无用处。

JustZix 安装只需 2 分钟,并在每个匹配的页面上运行你的代码。无需账户、无需付费。

免费下载 查看应用场景