← Todos los ejemplos

JavaScript Navegación quora.com

Quora: saltar entre respuestas con J/K

Añade los atajos J y K que desplazan suavemente a la respuesta siguiente o anterior.

Código para copiar

// Jump between answers with the J and K keys
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 answers = Array.prototype.slice.call(
    document.querySelectorAll('div[class*="puppeteer_test_answer_content"]')
  );
  if (!answers.length) { return; }
  const y = window.scrollY + 80;
  let idx = answers.findIndex(function (a) {
    return a.getBoundingClientRect().top + window.scrollY > y;
  });
  if (e.key === 'k') { idx = idx - 2; }
  idx = Math.max(0, Math.min(answers.length - 1, idx < 0 ? answers.length - 1 : idx));
  answers[idx].scrollIntoView({ behavior: 'smooth', block: 'start' });
});

Cómo usar este ejemplo

  1. Copia el código con el botón de arriba.
  2. Instala JustZix (2 minutos) y abre la extensión en la página de destino.
  3. Añade una nueva regla que coincida con esa página.
  4. Pega el código en el panel JavaScript de la regla y guarda — se ejecuta en cada visita a la página.

Valora este ejemplo

Sin valoraciones — sé el primero.

¿Funciona este ejemplo?

Los snippets son inútiles sin un lugar donde pegarlos.

JustZix se instala en 2 minutos y ejecuta tu código en cada página coincidente. Sin cuenta, sin pago.

Descargar gratis Ver casos de uso