← Tous les exemples

JavaScript Navigation

Naviguer dans les listes avec j/k

Les touches j et k déplacent une sélection style Vim dans les listes et les affichent.

Code à copier

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' });
});

Comment utiliser cet exemple

  1. Copiez le code avec le bouton ci-dessus.
  2. Installez JustZix (2 minutes) et ouvrez l'extension sur la page cible.
  3. Ajoutez une nouvelle règle correspondant à cette page.
  4. Collez le code dans le panneau JavaScript de la règle et enregistrez — il s'exécute à chaque visite de page.

Notez cet exemple

Aucune note — soyez le premier.

Cet exemple fonctionne-t-il ?

Les snippets sont inutiles sans un endroit où les coller.

JustZix s'installe en 2 minutes et exécute votre code sur chaque page correspondante. Sans compte, sans paiement.

Télécharger gratuitement Voir les cas d'usage