Quora:用 J/K 键在答案间跳转
添加 J 和 K 快捷键,平滑滚动到下一个或上一个答案。
可复制的代码
// Jump between answers with the J and K keys
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 answers = Array.prototype.slice.call(
document.querySelectorAll('div[class*="puppeteer_test_answer_content"]')
);
if (!answers.length) { return; }
const y = window.scrollY + 80;
let idx = answers.findIndex(function (a) {
return a.getBoundingClientRect().top + window.scrollY > y;
});
if (e.key === 'k') { idx = idx - 2; }
idx = Math.max(0, Math.min(answers.length - 1, idx < 0 ? answers.length - 1 : idx));
answers[idx].scrollIntoView({ behavior: 'smooth', block: 'start' });
});
如何使用此示例
- 用上方按钮复制代码。
- 安装 JustZix(2 分钟),在目标页面打开扩展。
- 添加一条匹配该页面的新规则。
- 将代码粘贴到规则的 JavaScript 面板并保存 — 每次访问页面时都会运行。
为此示例评分
暂无评分 — 成为第一个。