强大的无头UI表格库:TanStack Table!Github Star达到了惊人的25K!

news/2024/10/15 16:35:49

强大的无头UI表格库:TanStack Table!Github Star达到了惊人的25K!

在构建现代化 Web 应用时,表格数据网格是常见的 UI 组件,特别是在处理大量数据或需要复杂交互时,选择合适的表格库尤为重要。TanStack Table 是一款功能强大的 Headless UI 表格库,支持 TypeScript/JavaScriptReactVueSolidQwikSvelte 等多种框架。它提供了极高的灵活性和扩展性,适用于各种复杂的数据展示需求。它不仅可以处理简单的表格,还能够通过其高度可扩展的 API 满足复杂的数据网格需求。无论是分页排序过滤,还是多维分组虚拟滚动,它都能灵活应对,同时保持高效的性能表现。

今天,我们将深入介绍 TanStack Table,分析其显著特性、使用方式及适用场景,探讨为什么它是各大前端框架开发者的不二选择。
image

显著特性

  • 支持React、Vue、Solid 的一流框架绑定
  • ~15kb 或更少(使用 tree-shaking)
  • 100% TypeScript(但不是必需的)
  • 无头(100% 可定制,自带 UI)
  • 自动开箱即用,选择加入可控状态
  • 过滤器(列和全局)
  • 排序(多列、多方向)
  • 分组和聚合
  • 旋转(即将推出!)
  • 行选择
  • 行扩展
  • 列可见性/排序/固定/调整大小
  • 表分割
  • 可动画化
  • 可虚拟化
  • 服务器端/外部数据模型支持

为什么选择 TanStack Table?

  1. 多框架兼容,适用广泛

TanStack Table 支持多种前端框架,不管你是使用 React、Vue,还是新兴的 Solid 和 Svelte,都可以无缝集成。这种跨框架的能力使得它在不同技术栈项目中都非常适用。

  1. 轻量高效,性能优越

与其他捆绑了大量 UI 元素和功能的表格库不同,TanStack Table 保持了核心的轻量化,同时提供丰富的功能模块供按需加载。它的虚拟滚动功能在处理大数据集时尤为出色,确保用户交互的流畅性。

  1. 无 UI 限制,自定义能力强

对于那些需要高度定制化的项目,TanStack TableHeadless架构提供了极大的灵活性。你可以根据项目的具体需求,自由选择和设计表格的外观,而不被库自带的 UI 所限制。

  1. 扩展性强,满足复杂需求

无论是简单的数据展示,还是复杂的数据网格应用,TanStack Table 的插件扩展机制和高度可定制的 API 都能满足你的需求。你可以在不修改核心代码的情况下,快速实现复杂的功能需求。

适用场景

  1. 跨框架项目

TanStack Table 不局限于单一框架,它支持多种前端框架,如 React、Vue、Svelte、Solid 等,非常适合那些跨框架或需要高复用性的项目。

  1. 处理大数据集的应用

TanStack Table 轻量且支持虚拟滚动,在处理大数据集时,它能够仅渲染可视区域的数据,极大提升了性能表现。特别适合电商、管理系统等需要展示大量数据的应用场景。

  1. 需要高度定制表格样式的项目

如果项目对表格的外观有特定要求,TanStack Table 的无 UI 设计让你可以自由定制表格样式。结合你喜欢的 UI 库或自定义组件,打造完全符合需求的表格组件。

  1. 数据网格和复杂交互的场景

TanStack Table 提供了丰富的 API 和插件机制,支持复杂的数据交互逻辑,比如多维分组拖拽排序等功能,非常适合在 SaaS管理系统等需要处理复杂数据的场景中使用。

使用方式

安装

npm install @tanstack/vue-table

使用组件

image

比如,要实现上述复杂表格效果,需要用到的应用代码如下:

<script setup lang="ts">
import {FlexRender,getCoreRowModel,useVueTable,createColumnHelper,
} from '@tanstack/vue-table'
import { ref } from 'vue'type Person = {firstName: stringlastName: stringage: numbervisits: numberstatus: stringprogress: number
}const defaultData: Person[] = [{firstName: 'tanner',lastName: 'linsley',age: 24,visits: 100,status: 'In Relationship',progress: 50,},{firstName: 'tandy',lastName: 'miller',age: 40,visits: 40,status: 'Single',progress: 80,},{firstName: 'joe',lastName: 'dirte',age: 45,visits: 20,status: 'Complicated',progress: 10,},
]const columnHelper = createColumnHelper<Person>()const columns = [columnHelper.group({header: 'Name',footer: props => props.column.id,columns: [columnHelper.accessor('firstName', {cell: info => info.getValue(),footer: props => props.column.id,}),columnHelper.accessor(row => row.lastName, {id: 'lastName',cell: info => info.getValue(),header: () => 'Last Name',footer: props => props.column.id,}),],}),columnHelper.group({header: 'Info',footer: props => props.column.id,columns: [columnHelper.accessor('age', {header: () => 'Age',footer: props => props.column.id,}),columnHelper.group({header: 'More Info',columns: [columnHelper.accessor('visits', {header: () => 'Visits',footer: props => props.column.id,}),columnHelper.accessor('status', {header: 'Status',footer: props => props.column.id,}),columnHelper.accessor('progress', {header: 'Profile Progress',footer: props => props.column.id,}),],}),],}),
]const data = ref(defaultData)const rerender = () => {data.value = defaultData
}const table = useVueTable({get data() {return data.value},columns,getCoreRowModel: getCoreRowModel(),
})
</script><template><div class="p-2"><table><thead><trv-for="headerGroup in table.getHeaderGroups()":key="headerGroup.id"><thv-for="header in headerGroup.headers":key="header.id":colSpan="header.colSpan"><FlexRenderv-if="!header.isPlaceholder":render="header.column.columnDef.header":props="header.getContext()"/></th></tr></thead><tbody><tr v-for="row in table.getRowModel().rows" :key="row.id"><td v-for="cell in row.getVisibleCells()" :key="cell.id"><FlexRender:render="cell.column.columnDef.cell":props="cell.getContext()"/></td></tr></tbody><tfoot><trv-for="footerGroup in table.getFooterGroups()":key="footerGroup.id"><thv-for="header in footerGroup.headers":key="header.id":colSpan="header.colSpan"><FlexRenderv-if="!header.isPlaceholder":render="header.column.columnDef.footer":props="header.getContext()"/></th></tr></tfoot></table><div class="h-4" /><button @click="rerender" class="border p-2">Rerender</button></div>
</template><style>
html {font-family: sans-serif;font-size: 14px;
}table {border: 1px solid lightgray;
}tbody {border-bottom: 1px solid lightgray;
}th {border-bottom: 1px solid lightgray;border-right: 1px solid lightgray;padding: 2px 4px;
}tfoot {color: gray;
}tfoot th {font-weight: normal;
}
</style>

结语

TanStack Table 作为一款跨框架的强大表格库,凭借其高性能、轻量化和极致的定制能力,成为了现代 Web 开发中的理想选择。无论是在 React、Vue,还是其他前端框架中,它都能灵活应对复杂的数据展示和交互需求。如果你正在寻找一个可以满足从简单到复杂应用场景的表格库,TanStack Table 无疑是你的不二选择。


该框架已经收录到我的全栈前端一站式开发平台 “前端视界” 中(浏览器搜 前端视界 第一个),感兴趣的欢迎浏览使用!

image

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/71876.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

数据采集与融合技术作业1

作业1 1)用requests和BeautifulSoup库方法定向爬取给定网址(http://www.shanghairanking.cn/rankings/bcur/2020) 的数据,屏幕打印爬取的大学排名信息。 代码: # 使用 BeautifulSoup 解析 HTML soup = BeautifulSoup(html_content, html.parser)# 查找包含排名信息的表格 r…

【systemd】systemd功能简介及优化

1.systemd简介 Systemd是Linux系统工具,用来启动守护进程,已成为大多数发行版的标准配置。 历史上Linux的启动一直采用init进程,采用下面命令来启动服务: $ sudo /etc/init.d/apache2 start # 或者 $ service apache2 start1.启动时间长。init进程是串行启动,只有前一个进…

数据采集实验一

题目一 (1)要求:用requests和BeautifulSoup库方法定向爬取给定网址(http://www.shanghairanking.cn/rankings/bcur/2020)的数据,屏幕打印爬取的大学排名信息。python import requests from bs4 import BeautifulSoup# 目标网址 url = http://www.shanghairanking.cn/ranki…

Java面试题(持续更新中...)

各大公司Java面试题超详细总结!事务的四大特性 原子性,隔离性,持久性,一致性 事务的隔离级别和现象读未提交:可能产生脏读,读取到未提交的数据 读已提交:可能产生不可重复读取问题,A事务中读取到B事务已提交的数据,导致两次读取数据不一致 可重复读:可能产生幻读问题…

数据采集作业1

作业一 (1)实验内容 o 要求:用requests和BeautifulSoup库方法定向爬取给定网址(http://www.shanghairanking.cn/rankings/bcur/2020 )的数据,屏幕打印爬取的大学排名信息。 o 输出信息: 排名 学校名称 省市 学校类型 总分 1 清华大学 北京 综合 852.5 2 ...... 代码如下…

如何制作精美ppt(1)

现阶段人工智能有生成式人工智能、大语言模型、和ChatGPT,这三者之间为层级关系,生成式人工智能包含文本生成、图像生成、音频生成、视频生成。 现阶段推荐可使用的软件有:海螺AI 文小言(百度) Kimi智能助手(写论文适用) 智谱清言 制作过程要当成一种交流 1 沟通:作为上…

luogu 模拟赛

A.带余除法 我们不难考虑找出 \(q\) 的上下界,不难发现范围是 \([\lfloor\frac{n}{k+1}\rfloor+1,\lfloor\frac{n}{k}\rfloor]\)。当然这个区间可能为空。只需算出区间长度即可。 B.奖牌排序 不难考虑到分别按照三个关键字排序,然后对于每个小朋友找到每个关键字下的排名(同…

vue+wangEditor编辑器,上传图片请求后台接口

来吧,先给大家看一下,是否是你想要的简单轻便编辑器的效果。父组件:<EditorView :content="value" @change="grtUrl"/><script> import EditorView from "@/components/EditorView"; export default {components: {EditorView}},…