Sticky Headers in NetSuite

You know how NetSuite’s headers disappear when you scroll down and then you’re left to wonder which field you are in?

You can make the headers sticky with the following procedure (Chrome/Firefox/Brave):

  1. Install TamperMonkey (horrible name, great tool) from the add-on store.
  2. Once you’ve installed TamperMonkey, click the TamperMonkey icon and select “New User Script”
  3. Paste the following script into the new script window, and save the script.
// ==UserScript==
// @name NetSuite Floating Headers
// @version 0.2
// @description Float item sublist header on scroll
// @match https://**
// grant none
// @require
// ==/UserScript==

(function ($, undefined) {
    $(function () {
    const windowHeight = $(window).height();

        .filter((index, elem) => $(elem).height() > windowHeight)
        .css('height', '70vh')
        .bind('scroll', (event) => {
            const headerElem = $('.uir-machine-headerrow');
            headerElem.css('transform', `translate(0, ${}px)`);
        .bind('scroll', (event) => {
            const headerElem = $('.uir-list-headerrow');
            headerElem.css('transform', `translate(0, ${}px)`);


And that’s it! Now you have sticky headers in NetSuite!

Scrolling page with sticky NetSuite headers.
Voila! You now have sticky headers!

Hat tip to the folks at for posting the original suggested solution.

Let’s build something together.