How to create sticky table headers in a Nuxt UI Table Component?
I am trying to create "sticky table headers" so that way when the user scrolls a long list of table data rows, the headers stick to the top and visible in the viewport and keep the user informed of what the columns are.
I am using [NuxtUI Table component][1] in Nuxt3 and can not figure out how to get the headers to stick to the top. I tried doing the following:
But, that did not work.
Here's my reproduction link: https://stackblitz.com/edit/nuxt-ui-hg5dsj?file=app.vue
Anyone got a solution?
[1]: https://ui.nuxt.com/components/table
StackBlitz
Nuxt UI - Playground (forked) - StackBlitz
Playground of Nuxt UI, a UI library powered by Headless UI and Tailwind CSS for Nuxt.
4 Replies
it works when the overflow is removed from this div.
data:image/s3,"s3://crabby-images/ad866/ad8664b6b73d60c2ade324a1fc782812a26f41ac" alt="No description"
@localhostess has a good point.
I also found that making the ".overflow-x-auto:inherit", Let's you update any element you want to scroll and it'll abide.
so in this case we might want the "thead > tr" element to be visible, if so, then "thead > tr { overflow-x: visible;}" will keep that on top
and don't forget to add a bg color to the table headers, otherwise it'll be transparent, "tr > th { background: red;}"
data:image/s3,"s3://crabby-images/d147a/d147a612185f29b91ac66cb59f7903290e125ab0" alt="No description"
data:image/s3,"s3://crabby-images/0cfb4/0cfb439bd39a9c346347216a63bc36b43a927900" alt="No description"
data:image/s3,"s3://crabby-images/a2534/a2534111d2170ec7f9d32a2db47ec51701d4d302" alt="No description"
Updated the blitz https://stackblitz.com/edit/nuxt-ui-jorcn2?file=app.vue
snolan-ethika
StackBlitz
Nuxt UI - Playground (forked) - StackBlitz
Playground of Nuxt UI, a UI library powered by Headless UI and Tailwind CSS for Nuxt.
You can just set the 'thead'
:ui="{ wrapper: 'relative overflow-auto max-h-[40rem] min-h-96', thead: 'sticky top-0 bg-white' }"