X:用 J/K 键滚动推文
让你用 J(向下)和 K(向上)键平滑地在推文间切换,无需鼠标。
可复制的代码
// Smoothly scroll tweet-by-tweet with the J and K keys
function tweets() {
return Array.prototype.slice.call(document.querySelectorAll('[data-testid="tweet"]'));
}
function current(list) {
for (let i = 0; i < list.length; i++) {
if (list[i].getBoundingClientRect().top > 60) { return i; }
}
return list.length - 1;
}
document.addEventListener('keydown', function (e) {
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 = tweets();
if (!list.length) { return; }
let idx = current(list);
idx += (e.key === 'j') ? 1 : -1;
idx = Math.max(0, Math.min(list.length - 1, idx));
list[idx].scrollIntoView({ behavior: 'smooth', block: 'start' });
});
如何使用此示例
- 用上方按钮复制代码。
- 安装 JustZix(2 分钟),在目标页面打开扩展。
- 添加一条匹配该页面的新规则。
- 将代码粘贴到规则的 JavaScript 面板并保存 — 每次访问页面时都会运行。
为此示例评分
暂无评分 — 成为第一个。