← Tous les exemples

JavaScript Navigation stackoverflow.com

Stack Overflow : navigation clavier J/K entre réponses

Permet aux touches J et K de passer d'une réponse à l'autre sans utiliser la souris.

Code à copier

/* Use J / K keys to jump between answers */
(function () {
  var idx = -1;
  function answers() {
    return Array.prototype.slice.call(document.querySelectorAll('#answers .answer'));
  }
  document.addEventListener('keydown', function (e) {
    if (e.ctrlKey || e.altKey || e.metaKey) return;
    var tag = (e.target.tagName || '').toLowerCase();
    if (tag === 'input' || tag === 'textarea' || e.target.isContentEditable) return;
    var list = answers();
    if (!list.length) return;
    if (e.key === 'j') { idx = Math.min(idx + 1, list.length - 1); }
    else if (e.key === 'k') { idx = Math.max(idx - 1, 0); }
    else { return; }
    list[idx].scrollIntoView({ behavior: 'smooth', block: 'start' });
    e.preventDefault();
  });
})();

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