← Все примеры

JavaScript Навигация facebook.com

Facebook: навигация по постам клавишами J/K

Добавляет клавиши J и K, плавно прокручивающие к следующему и предыдущему посту.

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

// Add J/K keyboard shortcuts to jump between feed posts
function jumpPost(dir) {
  const posts = Array.prototype.slice.call(
    document.querySelectorAll('[role="feed"] [role="article"]'));
  const y = window.scrollY + 80;
  let target = null;
  if (dir > 0) {
    target = posts.find(function (p) { return p.offsetTop > y + 5; });
  } else {
    const before = posts.filter(function (p) { return p.offsetTop < y - 5; });
    target = before[before.length - 1];
  }
  if (target) { window.scrollTo({ top: target.offsetTop - 70, behavior: 'smooth' }); }
}
document.addEventListener('keydown', function (e) {
  const t = e.target;
  if (t && (t.isContentEditable || t.tagName === 'INPUT' || t.tagName === 'TEXTAREA')) { return; }
  if (e.key === 'j') { jumpPost(1); }
  if (e.key === 'k') { jumpPost(-1); }
});

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

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

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

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

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

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

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

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