← Wszystkie przykłady

JavaScript Czytanie i skupienie producthunt.com

Product Hunt: zwijaj wątki komentarzy

Dodaje przycisk zwijania przy każdym komentarzu najwyższego poziomu, by szybko ukryć długie wątki.

Kod do skopiowania

// 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 });
})();

Jak użyć tego przykładu

  1. Skopiuj kod przyciskiem powyżej.
  2. Zainstaluj JustZix (2 minuty) i otwórz wtyczkę na docelowej stronie.
  3. Dodaj nową regułę dopasowaną do tej strony.
  4. Wklej kod w panelu JavaScript reguły i zapisz — uruchomi się przy każdym wejściu na stronę.

Oceń ten przykład

Brak ocen — oceń jako pierwszy.

Czy ten przykład działa?

Snippety są bezużyteczne, jeśli nie masz gdzie ich wkleić.

JustZix instalujesz w 2 minuty i odpalasz swój kod na każdej pasującej stronie. Bez konta, bez opłat.

Pobierz za darmo Zobacz zastosowania