创建一个

元素来容纳表格:

让我们使用一些JavaScript将该元素转换为Tabulator:

$(\\\"#example-table\\\").tabulator();

就是这样,一个功能齐全的表格!

好的,我们还没完全完成。要完成我们的表格,我们需要定义列并加载一些数据。

定义列

要定义表格的布局,我们需要提供有关其每一列的一些信息。

我们通过将列定义数组传递给Tabulator构造函数来实现此目的。数组中的每个对象都表示表格的一列,并包含其设置参数:

$(\\\"#example-table\\\").tabulator({  columns:[    {title:\\\"Name\\\", field:\\\"name\\\", sortable:true, width:200},    {title:\\\"Progress\\\", field:\\\"progress\\\", sortable:true, sorter:\\\"number\\\"},    {title:\\\"Gender\\\", field:\\\"gender\\\", sortable:true},    {title:\\\"Favourite Color\\\", field:\\\"col\\\", sortable:false},    {title:\\\"Date Of Birth\\\", field:\\\"dob\\\"},    {title:\\\"Cheese Preference\\\", field:\\\"cheese\\\"},  ],});

有很多列参数可用,在本演示中,我们将介绍其中一些:

将数据加载到表格中

构建新的Tabulator的最后阶段是加载一些数据。这有几种选择,我们将在此处简要介绍每一种。

JavaScript数组

您可以使用setData方法传入一个数据数组。这需要一个数组,表格的每一行都由一个对象定义。

让我们创建一些示例数据:

var sampleData = [  {id:1, name:\\\"Oli Bob\\\", progress:12, gender:\\\"male\\\", rating:1, col:\\\"red\\\", dob:\\\"\\\", car:1, lucky_no:5, cheese:\\\"Cheader\\\"},  {id:2, name:\\\"Mary May\\\", progress:1, gender:\\\"female\\\", rating:2, col:\\\"blue\\\", dob:\\\"14/05/1982\\\", car:true, lucky_no:10, cheese:\\\"Gouda\\\"},  {id:3, name:\\\"Christine Lobowski\\\", progress:42, gender:\\\"female\\\", rating:0, col:\\\"green\\\", dob:\\\"22/05/1982\\\", car:\\\"true\\\", lucky_no:12, cheese:\\\"Manchego\\\"},  {id:4, name:\\\"Brendon Philips\\\", progress:100, gender:\\\"male\\\", rating:1, col:\\\"orange\\\", dob:\\\"01/08/1980\\\", lucky_no:18, cheese:\\\"Brie\\\"},  {id:5, name:\\\"Margret Marmajuke\\\", progress:16, gender:\\\"female\\\", rating:5, col:\\\"yellow\\\", dob:\\\"31/01/1999\\\", lucky_no:33, cheese:\\\"Cheader\\\"},];

然后将其分配给我们的表格:

$(\\\"#example-table\\\").tabulator(\\\"setData\\\", sampleData);

Ajax请求

要从远程源检索JSON格式的数据,您可以将URL传递给setData方法,它将为您执行Ajax请求。

$(\\\"#example-table\\\").tabulator(\\\"setData\\\", \\\"http://www.exampleurl.com/data\\\");

可以在包含URL的对象中传递其他请求参数。

$(\\\"#example-table\\\").tabulator(\\\"setData\\\", \\\"http://www.exampleurl.com/data\\\", {key1:\\\"value1\\\", key2:\\\"value2\\\"});

HTML表格

您还可以将现有的HTML表格转换为Tabulator。

创建您的HTML表格:

Name Progress Gender Height Favourite Color Date of Birth
Billy Bob 12 male 1 red
Mary May 1 female 2 blue 14/05/1982

然后在表格元素上调用Tabulator构造函数来自动提取标题和数据:

$(\\\"#example-table\\\").tabulator({});

最终结果

您已经构建了表格,定义了列并加载了数据,现在您拥有了一个功能齐全的交互式表格。您的工作Tabulator应该看起来像这样:(此处应插入CodePen链接或示例图片)

附加功能

但这还不是全部!当您可以做更多的事情来改善表格的外观、感觉和交互性时,为什么还要满足于简单的基于文本的表格呢?在接下来的几节中,我们将介绍您可以添加的一些附加功能来增强您的Tabulator。

(以下内容与原文类似,但需对语言进行调整和精简,并避免重复,保持流畅性。 可以考虑使用更简洁的段落和更精炼的语言来描述排序、格式化、过滤和编辑等功能,并适当添加一些示例代码。)

(排序、格式化、过滤、编辑等功能的描述,需精简并重新组织)

一个功能齐全的示例

如果我们将上面学到的所有课程结合起来,我们可以创建一个功能丰富、交互性强的表格。(此处应插入CodePen链接或示例图片)

冰山一角

我们已经介绍了如何创建一个基本的Tabulator并添加功能来增强其外观和可用性。

本文只介绍了创建和自定义表格时的冰山一角。该库包含许多功能,有助于为用户提供更丰富的体验:

我希望本文向您展示了如何将您的基本HTML表格提升到一个新的水平,为您的数据添加交互性和样式。

祝您Tabulator使用愉快!

(常见问题解答部分,需精简并重新组织)

(常见问题解答部分,需精简并重新组织) 可以将这部分内容精简为几个核心问题,并用简洁的语言回答。例如,可以合并几个关于如何使用JavaScript处理JSON数据并将其转换为HTML表格的问题,并提供一个概括性的答案。 避免重复,并确保答案准确且易于理解。

","image":"http://www.luping.net/uploads/20250222/174023497567b9e0dfc6502.jpg174023497567b9e0dfc650a.webp","datePublished":"2025-02-22T22:45:24+08:00","dateModified":"2025-02-22T22:45:24+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
”工欲善其事,必先利其器。“—孔子《论语.录灵公》

从任何JSON数据中以几秒钟的速度制作动态表

发布于2025-02-22
浏览:890

使用轻量级jQuery UI插件Tabulator轻松创建动态交互式表格!本文将指导您如何用极少的JavaScript代码,将JSON数据转换为动态、交互式表格。

Make Dynamic Tables in Seconds from Any JSON Data

核心要点:

  • 快速设置: Tabulator插件让您只需少量JavaScript代码,即可将JSON数据转换为动态、交互式表格。
  • 自定义列: 您可以通过标题、字段、排序、宽度和格式化程序等参数定义和自定义表格列,满足您的特定需求。
  • 灵活的数据加载: Tabulator支持多种数据加载方式,包括JavaScript数组、AJAX请求以及现有HTML表格的转换。
  • 增强的交互性: 内置排序、过滤和编辑功能,提供更出色的用户体验。
  • 扩展功能: 探索更多高级功能,例如自定义排序器和格式化程序、行分组、可移动列和分页,创建功能强大的表格。

本文由Stephan Max和Simon Codrington审核。感谢所有SitePoint的同行评审员,让SitePoint的内容尽善尽美!

Make Dynamic Tables in Seconds from Any JSON Data

标准HTML表格用于布局基本数据非常方便,但如果您需要更强大的表格功能呢?例如,从外部API获取数据、使表格可排序或可编辑,您就需要一个更强大的工具。

如果这听起来很熟悉,那么Tabulator就是您的理想选择。Tabulator是一个轻量级的jQuery UI插件,旨在简化复杂交互式表格的构建。只需几行JavaScript代码,您就可以将几乎任何数据源转换为格式精美、交互性强的表格。

本教程将引导您完成创建第一个Tabulator的基本步骤,然后扩展一些可用选项,为您的表格添加额外功能。

创建您的第一个Tabulator

让我们从创建一个非常简单的表格开始。

由于Tabulator是一个jQuery小部件,您需要包含jQuery和jQuery UI库,无论是来自本地源还是您选择的CDN。

您需要获取Tabulator库的副本(可从GitHub仓库克隆:https://github.com/olifolkerd/tabulator),并将`tabulator.css`和`tabulator.js`文件包含到您的项目中


创建一个

元素来容纳表格:

让我们使用一些JavaScript将该元素转换为Tabulator:

$("#example-table").tabulator();

就是这样,一个功能齐全的表格!

好的,我们还没完全完成。要完成我们的表格,我们需要定义列并加载一些数据。

定义列

要定义表格的布局,我们需要提供有关其每一列的一些信息。

我们通过将列定义数组传递给Tabulator构造函数来实现此目的。数组中的每个对象都表示表格的一列,并包含其设置参数:

$("#example-table").tabulator({
  columns:[
    {title:"Name", field:"name", sortable:true, width:200},
    {title:"Progress", field:"progress", sortable:true, sorter:"number"},
    {title:"Gender", field:"gender", sortable:true},
    {title:"Favourite Color", field:"col", sortable:false},
    {title:"Date Of Birth", field:"dob"},
    {title:"Cheese Preference", field:"cheese"},
  ],
});

有很多列参数可用,在本演示中,我们将介绍其中一些:

  • title必需 – 将在列标题中显示的标题
  • field必需 – 数据数组中列的键
  • align – 列的文本对齐方式 (left|center|right)
  • width – 列宽 (如果未设置,系统将确定最佳大小)
  • sortable – 切换用户是否可以按列排序数据
  • sorter – 如何对列中的数据进行排序 (默认为字符串)
  • formatter – 如何格式化列中的数据 (默认为字符串)
  • onClick – 用户单击列中的单元格时的回调函数
  • editable – 是否允许用户编辑此数据
  • editor – 当列中的单元格可编辑时使用的编辑器
  • visible – 显示或隐藏列

将数据加载到表格中

构建新的Tabulator的最后阶段是加载一些数据。这有几种选择,我们将在此处简要介绍每一种。

JavaScript数组

您可以使用setData方法传入一个数据数组。这需要一个数组,表格的每一行都由一个对象定义。

让我们创建一些示例数据:

var sampleData = [
  {id:1, name:"Oli Bob", progress:12, gender:"male", rating:1, col:"red", dob:"", car:1, lucky_no:5, cheese:"Cheader"},
  {id:2, name:"Mary May", progress:1, gender:"female", rating:2, col:"blue", dob:"14/05/1982", car:true, lucky_no:10, cheese:"Gouda"},
  {id:3, name:"Christine Lobowski", progress:42, gender:"female", rating:0, col:"green", dob:"22/05/1982", car:"true", lucky_no:12, cheese:"Manchego"},
  {id:4, name:"Brendon Philips", progress:100, gender:"male", rating:1, col:"orange", dob:"01/08/1980", lucky_no:18, cheese:"Brie"},
  {id:5, name:"Margret Marmajuke", progress:16, gender:"female", rating:5, col:"yellow", dob:"31/01/1999", lucky_no:33, cheese:"Cheader"},
];

然后将其分配给我们的表格:

$("#example-table").tabulator("setData", sampleData);

Ajax请求

要从远程源检索JSON格式的数据,您可以将URL传递给setData方法,它将为您执行Ajax请求。

$("#example-table").tabulator("setData", "http://www.exampleurl.com/data");

可以在包含URL的对象中传递其他请求参数。

$("#example-table").tabulator("setData", "http://www.exampleurl.com/data", {key1:"value1", key2:"value2"});

HTML表格

您还可以将现有的HTML表格转换为Tabulator。

创建您的HTML表格:

Name Progress Gender Height Favourite Color Date of Birth
Billy Bob 12 male 1 red
Mary May 1 female 2 blue 14/05/1982

然后在表格元素上调用Tabulator构造函数来自动提取标题和数据:

$("#example-table").tabulator({});

最终结果

您已经构建了表格,定义了列并加载了数据,现在您拥有了一个功能齐全的交互式表格。您的工作Tabulator应该看起来像这样:(此处应插入CodePen链接或示例图片)

附加功能

但这还不是全部!当您可以做更多的事情来改善表格的外观、感觉和交互性时,为什么还要满足于简单的基于文本的表格呢?在接下来的几节中,我们将介绍您可以添加的一些附加功能来增强您的Tabulator。

(以下内容与原文类似,但需对语言进行调整和精简,并避免重复,保持流畅性。 可以考虑使用更简洁的段落和更精炼的语言来描述排序、格式化、过滤和编辑等功能,并适当添加一些示例代码。)

(排序、格式化、过滤、编辑等功能的描述,需精简并重新组织)

一个功能齐全的示例

如果我们将上面学到的所有课程结合起来,我们可以创建一个功能丰富、交互性强的表格。(此处应插入CodePen链接或示例图片)

冰山一角

我们已经介绍了如何创建一个基本的Tabulator并添加功能来增强其外观和可用性。

本文只介绍了创建和自定义表格时的冰山一角。该库包含许多功能,有助于为用户提供更丰富的体验:

  • 行分组
  • 可移动行和列
  • 分页
  • CSS样式和主题
  • 大型数据集的渐进式渲染
  • 持久列布局 (将用户首选项存储在cookie中)
  • 在表格渲染的每个阶段和每种类型的用户交互时的回调函数

我希望本文向您展示了如何将您的基本HTML表格提升到一个新的水平,为您的数据添加交互性和样式。

祝您Tabulator使用愉快!

(常见问题解答部分,需精简并重新组织)

(常见问题解答部分,需精简并重新组织) 可以将这部分内容精简为几个核心问题,并用简洁的语言回答。例如,可以合并几个关于如何使用JavaScript处理JSON数据并将其转换为HTML表格的问题,并提供一个概括性的答案。 避免重复,并确保答案准确且易于理解。

最新教程 更多>
  • 如何有效地选择熊猫数据框中的列?
    如何有效地选择熊猫数据框中的列?
    在处理数据操作任务时,在Pandas DataFrames 中选择列,选择特定列的必要。在Pandas中,选择列的各种选项。选项1:使用列名 如果已知列索引,请使用ILOC函数选择它们。请注意,python索引基于零。 df1 = df.iloc [:,0:2]#使用索引0和1 的 column_...
    编程 发布于2025-04-09
  • 如何配置Pytesseract以使用数字输出的单位数字识别?
    如何配置Pytesseract以使用数字输出的单位数字识别?
    Pytesseract OCR具有单位数字识别和仅数字约束 在pytesseract的上下文中,在配置tesseract以识别单位数字和限制单个数字和限制输出对数字可能会提出质疑。 To address this issue, we delve into the specifics of Te...
    编程 发布于2025-04-09
  • 为什么我的CSS背景图像出现?
    为什么我的CSS背景图像出现?
    故障排除:CSS背景图像未出现 ,您的背景图像尽管遵循教程说明,但您的背景图像仍未加载。图像和样式表位于相同的目录中,但背景仍然是空白的白色帆布。而不是不弃用的,您已经使用了CSS样式: bockent {背景:封闭图像文件名:背景图:url(nickcage.jpg); 如果您的html,css...
    编程 发布于2025-04-09
  • 在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    在Ubuntu/linux上安装mysql-python时,如何修复\“ mysql_config \”错误?
    mysql-python安装错误:“ mysql_config找不到”“ 由于缺少MySQL开发库而出现此错误。解决此问题,建议在Ubuntu上使用该分发的存储库。使用以下命令安装Python-MysqldB: sudo apt-get安装python-mysqldb sudo pip in...
    编程 发布于2025-04-09
  • 如何使用node-mysql在单个查询中执行多个SQL语句?
    如何使用node-mysql在单个查询中执行多个SQL语句?
    在node-mysql node-mysql文档最初出于安全原因最初禁用多个语句支持,因为它可能导致SQL注入攻击。要启用此功能,您需要在创建连接时将倍增设置设置为true: var connection = mysql.createconnection({{multipleStatement:...
    编程 发布于2025-04-09
  • 如何在无序集合中为元组实现通用哈希功能?
    如何在无序集合中为元组实现通用哈希功能?
    在未订购的集合中的元素要纠正此问题,一种方法是手动为特定元组类型定义哈希函数,例如: template template template 。 struct std :: hash { size_t operator()(std :: tuple const&tuple)const {...
    编程 发布于2025-04-09
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-04-09
  • 如何使用“ JSON”软件包解析JSON阵列?
    如何使用“ JSON”软件包解析JSON阵列?
    parsing JSON与JSON软件包 QUALDALS:考虑以下go代码:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    编程 发布于2025-04-09
  • 为什么不使用CSS`content'属性显示图像?
    为什么不使用CSS`content'属性显示图像?
    在Firefox extemers属性为某些图像很大,&& && && &&华倍华倍[华氏华倍华氏度]很少见,却是某些浏览属性很少,尤其是特定于Firefox的某些浏览器未能在使用内容属性引用时未能显示图像的情况。这可以在提供的CSS类中看到:。googlepic { 内容:url(&#...
    编程 发布于2025-04-09
  • 您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    您可以使用CSS在Chrome和Firefox中染色控制台输出吗?
    在javascript console 中显示颜色是可以使用chrome的控制台显示彩色文本,例如红色的redors,for for for for错误消息?回答是的,可以使用CSS将颜色添加到Chrome和Firefox中的控制台显示的消息(版本31或更高版本)中。要实现这一目标,请使用以下模...
    编程 发布于2025-04-09
  • 可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    [2这里: https://webthemez.com/demo/sticky-multi-header-scroll/index.html </main> <section> { display:grid; grid-template-...
    编程 发布于2025-04-09
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-04-09
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-04-09
  • 如何在Java的全屏独家模式下处理用户输入?
    如何在Java的全屏独家模式下处理用户输入?
    Handling User Input in Full Screen Exclusive Mode in JavaIntroductionWhen running a Java application in full screen exclusive mode, the usual event ha...
    编程 发布于2025-04-09
  • 在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在细胞编辑后,如何维护自定义的JTable细胞渲染?
    在JTable中维护jtable单元格渲染后,在JTable中,在JTable中实现自定义单元格渲染和编辑功能可以增强用户体验。但是,至关重要的是要确保即使在编辑操作后也保留所需的格式。在设置用于格式化“价格”列的“价格”列,用户遇到的数字格式丢失的“价格”列的“价格”之后,问题在设置自定义单元格...
    编程 发布于2025-04-09

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3