← Все примеры

JavaScript Навигация

Навигация по списку клавишами j/k

Клавиши j и k перемещают выбор в стиле Vim по элементам списка.

Код для копирования

var items = Array.prototype.slice.call(
  document.querySelectorAll('article, li, .item, [role="listitem"]')
).filter(function (el) { return el.offsetHeight > 20; });
var idx = -1;
document.addEventListener('keydown', function (e) {
  if (e.target.matches('input, textarea, select, [contenteditable]')) { return; }
  if (e.key !== 'j' && e.key !== 'k') { return; }
  if (!items.length) { return; }
  if (idx >= 0) { items[idx].style.outline = ''; }
  idx = e.key === 'j' ? Math.min(idx + 1, items.length - 1)
                      : Math.max(idx - 1, 0);
  items[idx].style.outline = '3px solid #006870';
  items[idx].scrollIntoView({ behavior: 'smooth', block: 'center' });
});

Как использовать этот пример

  1. Скопируй код кнопкой выше.
  2. Установи JustZix (2 минуты) и открой расширение на нужной странице.
  3. Добавь новое правило, совпадающее с этой страницей.
  4. Вставь код в панель JavaScript правила и сохрани — он запускается при каждом заходе на страницу.

Оцени этот пример

Оценок пока нет — оцени первым.

Этот пример работает?

Сниппеты бесполезны, если их некуда вставить.

JustZix устанавливается за 2 минуты и запускает твой код на каждой подходящей странице. Без аккаунта, без оплаты.

Скачать бесплатно Смотреть применение