{"id":14962532,"url":"https://github.com/tanstack/virtual","last_synced_at":"2026-03-05T23:18:21.177Z","repository":{"id":37092419,"uuid":"262255533","full_name":"TanStack/virtual","owner":"TanStack","description":"🤖 Headless UI for Virtualizing Large Element Lists in JS/TS, React, Solid, Vue and Svelte","archived":false,"fork":false,"pushed_at":"2025-04-28T06:51:06.000Z","size":7334,"stargazers_count":6032,"open_issues_count":70,"forks_count":340,"subscribers_count":34,"default_branch":"main","last_synced_at":"2025-04-30T21:54:33.987Z","etag":null,"topics":["javascript","performance","react","reactjs","scrolling","solid","solidjs","svelte","virtualization","virtualized","vue"],"latest_commit_sha":null,"homepage":"https://tanstack.com/virtual","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/TanStack.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"CONTRIBUTING.md","funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null},"funding":{"github":"tannerlinsley","custom":"https://youtube.com/tannerlinsley"}},"created_at":"2020-05-08T07:25:21.000Z","updated_at":"2025-04-30T21:48:46.000Z","dependencies_parsed_at":"2023-12-04T20:25:47.310Z","dependency_job_id":"b8af3bba-a48f-48bc-befa-afc9e13d87c3","html_url":"https://github.com/TanStack/virtual","commit_stats":{"total_commits":278,"total_committers":59,"mean_commits":4.711864406779661,"dds":0.6330935251798562,"last_synced_commit":"623ac63988f16e6ea6755d8b2e190c123134501c"},"previous_names":["tannerlinsley/react-virtual","tanstack/react-virtual"],"tags_count":192,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TanStack%2Fvirtual","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TanStack%2Fvirtual/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TanStack%2Fvirtual/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/TanStack%2Fvirtual/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/TanStack","download_url":"https://codeload.github.com/TanStack/virtual/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":251789579,"owners_count":21644082,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["javascript","performance","react","reactjs","scrolling","solid","solidjs","svelte","virtualization","virtualized","vue"],"created_at":"2024-09-24T13:29:55.623Z","updated_at":"2026-01-06T13:17:39.174Z","avatar_url":"https://github.com/TanStack.png","language":"TypeScript","funding_links":["https://github.com/sponsors/tannerlinsley","https://youtube.com/tannerlinsley","https://github.com/sponsors/tannerlinsley/"],"categories":[],"sub_categories":[],"readme":"\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"./media/header_virtual.png\" alt=\"Tanstack Virtual\"\u003e\n\u003c/div\u003e\n\n\u003cbr /\u003e\n\n\u003cdiv align=\"center\"\u003e\n\t\u003ca href=\"https://npmjs.com/package/@tanstack/virtual-core\" target=\"\\_parent\"\u003e\n  \u003cimg alt=\"npm downloads\" src=\"https://img.shields.io/npm/dm/@tanstack/virtual-core.svg\" /\u003e\n\u003c/a\u003e\n\t\u003ca href=\"https://github.com/tanstack/virtual\" target=\"\\_parent\"\u003e\n  \u003cimg alt=\"github stars\" src=\"https://img.shields.io/github/stars/tanstack/virtual.svg?style=social\u0026label=Star\" /\u003e\n\u003c/a\u003e\n\u003ca href=\"https://bundlephobia.com/result?p=@tanstack/virtual-core@latest\" target=\"\\_parent\"\u003e\n  \u003cimg alt=\"bundle size\" src=\"https://badgen.net/bundlephobia/minzip/@tanstack/virtual-core@latest\" /\u003e\n\u003c/a\u003e\n\u003c/div\u003e\n\n\u003cdiv align=\"center\"\u003e\n\t\u003ca href=\"#badge\"\u003e\n    \u003cimg alt=\"semantic-release\" src=\"https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg\"\u003e\n  \u003c/a\u003e\n\t\u003ca href=\"https://bestofjs.org/projects/tanstack-virtual\"\u003e\n\t\t\u003cimg alt=\"Best of JS\" src=\"https://img.shields.io/endpoint?url=https://bestofjs-serverless.now.sh/api/project-badge?fullName=TanStack%2Fvirtual%26since=daily\" alt=\"Best of JS\"/\u003e\n\t\u003c/a\u003e\n\t\u003ca href=\"https://twitter.com/tan_stack\"\u003e\n\t\t\u003cimg src=\"https://img.shields.io/twitter/follow/tan_stack.svg?style=social\" alt=\"Follow @TanStack\"/\u003e\n\t\u003c/a\u003e\n\u003c/div\u003e\n\n\u003cdiv align=\"center\"\u003e\n\n### [Become a Sponsor!](https://github.com/sponsors/tannerlinsley/)\n\n\u003c/div\u003e\n\n# TanStack Virtual\n\nA headless, framework‑agnostic virtualization library for rendering massive lists, grids, and tables at 60FPS while giving you full control over markup and styles.\n\n- Framework‑agnostic \u0026 headless\n- Virtualizes vertical, horizontal \u0026 grid layouts with a single hook/function\n- Lightweight (10–15kb) yet powerful, with dynamic \u0026 measured sizing support\n- Smooth 60FPS scrolling with sticky items and window‑scrolling utilities\n\n### \u003ca href=\"https://tanstack.com/virtual\" \u003eRead the docs →\u003c/a\u003e\n\n## Get Involved\n\n- We welcome issues and pull requests!\n- Participate in [GitHub discussions](https://github.com/TanStack/virtual/discussions)\n- Chat with the community on [Discord](https://discord.com/invite/WrRKjPJ)\n- See [CONTRIBUTING.md](./CONTRIBUTING.md) for setup instructions\n\n## Partners\n\n\u003ctable align=\"center\"\u003e\n  \u003ctr\u003e\n    \u003ctd\u003e\n        \u003ca href=\"https://www.coderabbit.ai/?via=tanstack\u0026dub_id=aCcEEdAOqqutX6OS\"\u003e\n\t\t\t\u003cpicture\u003e\n\t\t\t  \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"https://tanstack.com/assets/coderabbit-dark-CMcuvjEy.svg\" height=\"40\" /\u003e\n\t\t\t  \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"https://tanstack.com/assets/coderabbit-light-DVMJ2jHi.svg\" height=\"40\" /\u003e\n\t\t\t  \u003cimg src=\"https://tanstack.com/assets/coderabbit-light-DVMJ2jHi.svg\" height=\"40\" alt=\"CodeRabbit\" /\u003e\n\t\t\t\u003c/picture\u003e        \n\t\t\u003c/a\u003e\n    \u003c/td\u003e\n    \u003ctd padding=\"20\"\u003e\n      \u003ca href=\"https://www.cloudflare.com?utm_source=tanstack\"\u003e\n         \u003cpicture\u003e\n\t\t  \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"https://tanstack.com/assets/cloudflare-white-DQDB7UaL.svg\" height=\"60\" /\u003e\n\t\t  \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"https://tanstack.com/assets/cloudflare-black-CPufaW0B.svg\" height=\"60\" /\u003e\n\t\t  \u003cimg src=\"https://tanstack.com/assets/cloudflare-black-CPufaW0B.svg\" height=\"60\" alt=\"Cloudflare\" /\u003e\n\t\t\u003c/picture\u003e\n      \u003c/a\u003e\n    \u003c/td\u003e\n  \u003c/tr\u003e\n\u003c/table\u003e\n  \n \n\u003cdiv align=\"center\"\u003e\n\u003cimg src=\"./media/partner_logo.svg\" alt=\"Virtual \u0026 you?\" height=\"65\"\u003e\n\u003cp\u003e\nWe're looking for TanStack Virtual Partners to join our mission! Partner with us to push the boundaries of TanStack Virtual and build amazing things together.\n\u003c/p\u003e\n\u003ca href=\"mailto:partners@tanstack.com?subject=TanStack Virtual Partnership\"\u003e\u003cb\u003eLET'S CHAT\u003c/b\u003e\u003c/a\u003e\n\u003c/div\u003e\n  \n## Explore the TanStack Ecosystem\n\n- \u003ca href=\"https://github.com/tanstack/config\"\u003e\u003cb\u003eTanStack Config\u003c/b\u003e\u003c/a\u003e – Tooling for JS/TS packages\n- \u003ca href=\"https://github.com/tanstack/db\"\u003e\u003cb\u003eTanStack DB\u003c/b\u003e\u003c/a\u003e – Reactive sync client store\n- \u003ca href=\"https://github.com/tanstack/devtools\"\u003e\u003cb\u003eTanStack DevTools\u003c/b\u003e\u003c/a\u003e – Unified devtools panel\n- \u003ca href=\"https://github.com/tanstack/form\"\u003e\u003cb\u003eTanStack Form\u003c/b\u003e\u003c/a\u003e – Type‑safe form state\n- \u003ca href=\"https://github.com/tanstack/pacer\"\u003e\u003cb\u003eTanStack Pacer\u003c/b\u003e\u003c/a\u003e – Debouncing, throttling, batching \u003cbr/\u003e\n- \u003ca href=\"https://github.com/tanstack/query\"\u003e\u003cb\u003eTanStack Query\u003c/b\u003e\u003c/a\u003e – Async state \u0026 caching\n- \u003ca href=\"https://github.com/tanstack/ranger\"\u003e\u003cb\u003eTanStack Ranger\u003c/b\u003e\u003c/a\u003e – Range \u0026 slider primitives\n- \u003ca href=\"https://github.com/tanstack/router\"\u003e\u003cb\u003eTanStack Router\u003c/b\u003e\u003c/a\u003e – Type‑safe routing, caching \u0026 URL state\n- \u003ca href=\"https://github.com/tanstack/router\"\u003e\u003cb\u003eTanStack Start\u003c/b\u003e\u003c/a\u003e – Full‑stack SSR \u0026 streaming\n- \u003ca href=\"https://github.com/tanstack/store\"\u003e\u003cb\u003eTanStack Store\u003c/b\u003e\u003c/a\u003e – Reactive data store\n- \u003ca href=\"https://github.com/tanstack/table\"\u003e\u003cb\u003eTanStack Table\u003c/b\u003e\u003c/a\u003e – Headless datagrids\n\n… and more at \u003ca href=\"https://tanstack.com\"\u003e\u003cb\u003eTanStack.com »\u003c/b\u003e\u003c/a\u003e\n\n\u003c!-- Use the force, Luke --\u003e\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftanstack%2Fvirtual","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Ftanstack%2Fvirtual","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Ftanstack%2Fvirtual/lists"}