← 全部示例

JavaScript 导航 reddit.com

Reddit:用 J 和 K 键跳转帖子

添加 J 和 K 快捷键,平滑滚动信息流到下一个或上一个帖子。

可复制的代码

// Jump between feed posts with the J and K keys
function posts() {
  return Array.prototype.slice.call(document.querySelectorAll('shreddit-post'));
}
function current(list) {
  return list.findIndex(function (p) {
    const r = p.getBoundingClientRect();
    return r.top >= -2 && r.top < window.innerHeight / 2;
  });
}
document.addEventListener('keydown', function (e) {
  if (e.ctrlKey || e.metaKey || e.altKey) { return; }
  const tag = (e.target.tagName || '').toLowerCase();
  if (tag === 'input' || tag === 'textarea' || e.target.isContentEditable) { return; }
  if (e.key !== 'j' && e.key !== 'k') { return; }
  const list = posts();
  if (!list.length) { return; }
  let i = current(list);
  if (i < 0) { i = 0; }
  i += (e.key === 'j' ? 1 : -1);
  i = Math.max(0, Math.min(list.length - 1, i));
  list[i].scrollIntoView({ behavior: 'smooth', block: 'start' });
});

如何使用此示例

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

为此示例评分

暂无评分 — 成为第一个。

此示例有效吗?

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

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

免费下载 查看应用场景