← All examples

JavaScript Productivity news.ycombinator.com

Hacker News: j/k keyboard navigation

Lets you step between comments and stories with the j and k keys, outlining the current item.

Code to copy

// 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); }
  });
})();

How to use this example

  1. Copy the code with the button above.
  2. Install JustZix (2 minutes) and open the extension on the target page.
  3. Add a new rule matching that page.
  4. Paste the code into the rule's JavaScript panel and save — it runs on every page visit.

Rate this example

No ratings yet — be the first.

Does this example work?

Snippets are useless without somewhere to paste them.

JustZix takes 2 minutes to install and runs your code on every matching page. No account, no payment.

Download free See use cases