← All examples

JavaScript Navigation notion.so

Number page headings

Adds sequential numbers before top-level headings to make a long page structure easier to follow.

Code to copy

(function () {
  try {
    var heads = document.querySelectorAll('.notion-page-content .notion-header-block');
    var i = 0;
    heads.forEach(function (h) {
      if (h.dataset.jzNum) return;
      i++;
      var t = h.querySelector('.notranslate');
      if (t) t.insertAdjacentText('afterbegin', i + '. ');
      h.dataset.jzNum = '1';
    });
    if (!heads.length) alert('No top-level headings found.');
  } catch (e) { alert('Could not number headings: ' + e.message); }
})();

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