← Tous les exemples

JavaScript Navigation reddit.com

Reddit : naviguer entre posts avec J et K

Ajoute les raccourcis J et K pour faire défiler en douceur le fil vers le post suivant ou précédent.

Code à copier

// Jump between feed posts with the J and K keys
function posts() {
  return Array.prototype.slice.call(document.querySelectorAll('shreddit-post'));
}
function current(list) {
  return list.findIndex(function (p) {
    const r = p.getBoundingClientRect();
    return r.top >= -2 && r.top < window.innerHeight / 2;
  });
}
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 list = posts();
  if (!list.length) { return; }
  let i = current(list);
  if (i < 0) { i = 0; }
  i += (e.key === 'j' ? 1 : -1);
  i = Math.max(0, Math.min(list.length - 1, i));
  list[i].scrollIntoView({ behavior: 'smooth', block: 'start' });
});

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