← Все примеры

JavaScript Чтение и фокус producthunt.com

Product Hunt: сворачиваемые ветки комментариев

Добавляет кнопку сворачивания к каждому комментарию верхнего уровня, чтобы быстро скрыть длинные ветки.

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

// Add a click-to-collapse toggle to each top-level comment
(function () {
  function patch() {
    document.querySelectorAll('[data-test^="comment-"]').forEach(function (c) {
      if (c.dataset.jzCollapse) { return; }
      if (c.closest('[data-test^="comment-"] [data-test^="comment-"]')) { return; }
      c.dataset.jzCollapse = '1';
      var btn = document.createElement('button');
      btn.textContent = '[-]';
      btn.style.cssText = 'cursor:pointer;margin-right:6px;border:none;background:none;color:#da552f;font-weight:700;';
      btn.addEventListener('click', function () {
        var hidden = c.dataset.jzHidden === '1';
        Array.from(c.children).forEach(function (ch) {
          if (ch !== btn.parentNode) { ch.style.display = hidden ? '' : 'none'; }
        });
        c.dataset.jzHidden = hidden ? '0' : '1';
        btn.textContent = hidden ? '[-]' : '[+]';
      });
      var head = document.createElement('div');
      head.appendChild(btn);
      c.insertBefore(head, c.firstChild);
    });
  }
  patch();
  var obs = new MutationObserver(function () {
    clearTimeout(window.__jzPrhCollapse);
    window.__jzPrhCollapse = setTimeout(patch, 500);
  });
  obs.observe(document.body, { childList: true, subtree: true });
})();

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

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

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

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

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

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

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

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