← 全部示例

JavaScript 导航 facebook.com

Facebook:J/K 键浏览帖子

添加 J 和 K 键,平滑滚动到下一个和上一个帖子。

可复制的代码

// Add J/K keyboard shortcuts to jump between feed posts
function jumpPost(dir) {
  const posts = Array.prototype.slice.call(
    document.querySelectorAll('[role="feed"] [role="article"]'));
  const y = window.scrollY + 80;
  let target = null;
  if (dir > 0) {
    target = posts.find(function (p) { return p.offsetTop > y + 5; });
  } else {
    const before = posts.filter(function (p) { return p.offsetTop < y - 5; });
    target = before[before.length - 1];
  }
  if (target) { window.scrollTo({ top: target.offsetTop - 70, behavior: 'smooth' }); }
}
document.addEventListener('keydown', function (e) {
  const t = e.target;
  if (t && (t.isContentEditable || t.tagName === 'INPUT' || t.tagName === 'TEXTAREA')) { return; }
  if (e.key === 'j') { jumpPost(1); }
  if (e.key === 'k') { jumpPost(-1); }
});

如何使用此示例

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

为此示例评分

暂无评分 — 成为第一个。

此示例有效吗?

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

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

免费下载 查看应用场景