← All examples

JavaScript Reading & focus stackoverflow.com

Stack Overflow: collapse comments by default

Collapses comment threads under the question and answers, while clicking the "show" link still expands them.

Code to copy

/* Collapse all comment threads by default */
(function () {
  function collapse() {
    document.querySelectorAll('.comments').forEach(function (c) {
      if (c.dataset.sofCollapsed) return;
      c.dataset.sofCollapsed = '1';
      var list = c.querySelector('.comments-list');
      if (list) list.style.display = 'none';
    });
    document.querySelectorAll('.js-show-link.comments-link').forEach(function (link) {
      link.addEventListener('click', function () {
        var box = link.closest('.comments');
        var list = box && box.querySelector('.comments-list');
        if (list) list.style.display = '';
      });
    });
  }
  collapse();
  new MutationObserver(collapse).observe(document.body, { childList: true, subtree: true });
})();

How to use this example

  1. Copy the code with the button above.
  2. Install JustZix (2 minutes) and open the extension on the target page.
  3. Add a new rule matching that page.
  4. Paste the code into the rule's JavaScript panel and save — it runs on every page visit.

Rate this example

No ratings yet — be the first.

Does this example work?

Snippets are useless without somewhere to paste them.

JustZix takes 2 minutes to install and runs your code on every matching page. No account, no payment.

Download free See use cases