JavaScript:将JSON数组按日期分组并格式化输出到HTML

javascript:将json数组按日期分组并格式化输出到html

本教程详细介绍了如何利用JavaScript处理JSON数组,将其中的数据按日期字段进行分组,并最终生成符合特定格式要求的HTML页面或文本输出。我们将重点讲解reduce方法进行数据聚合,并演示如何遍历分组后的数据以构建结构化的显示内容,确保数据以日期为标题,其下展示对应的分类和时间信息。

前端开发中,我们经常需要将从后端获取的扁平化JSON数据转换为更具可读性和结构化的展示形式。一个常见的场景是,将包含日期、类别和时间等信息的列表,按照日期进行分组,并在每个日期下显示对应的详细条目。本文将指导您完成这一转换过程。

1. 理解原始数据结构

我们首先来看一个典型的JSON数组示例。每个对象都包含category(类别)、date(日期)和time1(时间)字段。

const myArray = [  { 'category': 'apple', 'date': '20/4/2023', 'time1': '12:30' },  { 'category': 'banana', 'date': '20/4/2023', 'time1': '12:32' },  { 'category': 'tv', 'date': '21/4/2023', 'time1': '12:34' },  { 'category': 'banana', 'date': '21/4/2023', 'time1': '12:39' },];

我们的目标是将其转换为以下格式的输出:

----------20/4/2023-------------apple 12:30banana 12:32----------21/4/2023-------------tv 12:34banana 12:39

2. 数据分组:使用Array.prototype.reduce()

实现数据分组最有效的方法之一是使用JavaScript数组的reduce()方法。reduce()方法对数组中的每个元素执行一个由您提供的reducer函数,将其结果汇总为单个返回值。

立即学习“Java免费学习笔记(深入)”;

在这个场景中,我们将reduce()用于创建一个新的对象,其中键是日期,值是该日期下所有相关条目的数组。

const groupedData = myArray.reduce((accumulator, currentItem) => {  const date = currentItem.date;  // 如果accumulator中还没有这个日期作为键,则创建一个空数组  if (!accumulator[date]) {    accumulator[date] = [];  }  // 将当前项的相关信息(类别和时间)推入对应日期的数组  accumulator[date].push({ category: currentItem.category, time1: currentItem.time1 });  return accumulator; // 返回更新后的accumulator}, {}); // 初始accumulator是一个空对象console.log(groupedData);/*输出示例:{  '20/4/2023': [    { category: 'apple', time1: '12:30' },    { category: 'banana', time1: '12:32' }  ],  '21/4/2023': [    { category: 'tv', time1: '12:34' },    { category: 'banana', time1: '12:39' }  ]}*/

代码解析:

Unreal Images Unreal Images

免费的AI图片库

Unreal Images 53 查看详情 Unreal Images accumulator (acc):累加器,它在每次迭代中存储reduce函数的返回值,并作为下一次迭代的第一个参数。在这里,它将构建最终的分组对象。currentItem (curr):数组中正在处理的当前元素。currentItem.date:提取当前元素的日期。if (!accumulator[date]) { accumulator[date] = []; }:这是一个关键步骤。它检查accumulator对象是否已经有了当前日期作为键。如果没有,它就为该日期创建一个新的空数组。accumulator[date].push(…):将当前条目的category和time1信息作为一个新对象推入对应日期的数组中。{}:reduce方法的第二个参数,表示accumulator的初始值,这里是一个空对象。

3. 格式化输出到HTML或文本

数据分组完成后,下一步是遍历groupedData对象,并按照期望的格式生成输出字符串。这个字符串可以直接打印到控制台,也可以插入到HTML页面中。

let outputString = '';// 遍历groupedData对象,键是日期,值是该日期下的条目数组for (const date in groupedData) {  // 确保只处理对象自身的属性,而不是原型链上的属性  if (Object.hasOwnProperty.call(groupedData, date)) {    // 添加日期标题行    outputString += `----------${date}-------------n`;    // 遍历该日期下的所有条目    groupedData[date].forEach(item => {      outputString += `${item.category} ${item.time1}n`;    });  }}console.log(outputString);

代码解析:

for (const date in groupedData):循环遍历groupedData对象的所有键(即日期)。Object.hasOwnProperty.call(groupedData, date):这是一个最佳实践,用于确保我们只处理对象自身的属性,避免遍历到原型链上的属性。outputString += ———-${date}————-n`;:使用模板字符串方便地构建日期标题行。n`用于换行。groupedData[date].forEach(item => { … });:对于每个日期,我们遍历其对应的条目数组,并为每个条目生成category time1格式的行。

4. 完整代码示例

将上述两个步骤结合起来,形成一个完整的解决方案:

const myArray = [  { 'category': 'apple', 'date': '20/4/2023', 'time1': '12:30' },  { 'category': 'banana', 'date': '20/4/2023', 'time1': '12:32' },  { 'category': 'tv', 'date': '21/4/2023', 'time1': '12:34' },  { 'category': 'banana', 'date': '21/4/2023', 'time1': '12:39' },];// 步骤 1: 按日期分组数据const groupedData = myArray.reduce((accumulator, currentItem) => {  const date = currentItem.date;  if (!accumulator[date]) {    accumulator[date] = [];  }  accumulator[date].push({ category: currentItem.category, time1: currentItem.time1 });  return accumulator;}, {});// 步骤 2: 格式化输出字符串let outputString = '';for (const date in groupedData) {  if (Object.hasOwnProperty.call(groupedData, date)) {    outputString += `----------${date}-------------n`;    groupedData[date].forEach(item => {      outputString += `${item.category} ${item.time1}n`;    });  }}console.log(outputString);// 如果要在HTML页面中显示,可以这样做:// const outputElement = document.getElementById('output'); // 假设有一个id为'output'的pre或div元素// if (outputElement) {//   outputElement.textContent = outputString; // 使用textContent避免HTML注入风险//   // 或者如果需要渲染为HTML结构,则需要构建DOM元素//   // let htmlOutput = '';//   // for (const date in groupedData) {//   //   if (Object.hasOwnProperty.call(groupedData, date)) {//   //     htmlOutput += `

----------${date}-------------

`;// // groupedData[date].forEach(item => {// // htmlOutput += `

${item.category} ${item.time1}

`;// // });// // }// // }// // outputElement.innerHTML = htmlOutput;// }

5. 注意事项与优化

日期格式一致性:确保JSON数据中的日期格式保持一致,否则分组将无法正确进行。如果日期格式多样,您可能需要在分组前对其进行标准化处理。

性能考量:对于非常庞大的数据集,reduce方法通常是高效的。但如果数据量极其巨大,可能需要考虑流式处理或后端聚合。

HTML渲染:上述示例生成的是一个纯文本字符串。若要将其渲染到HTML页面中,您应将n替换为
标签,并考虑使用document.createElement和appendChild等DOM操作方法来动态创建HTML元素,而不是直接使用innerHTML,以避免潜在的XSS(跨站脚本攻击)风险。

错误处理:在实际应用中,您可能需要添加逻辑来处理数据中可能缺失category、date或time1字段的情况。

日期排序:for…in循环遍历对象的属性时,属性的顺序不保证是按照日期顺序的。如果需要按日期顺序显示,您需要先获取groupedData的所有键(日期),然后对这些日期进行排序,再按排序后的日期顺序遍历。

const sortedDates = Object.keys(groupedData).sort((a, b) => {  // 假设日期格式是 DD/MM/YYYY,需要转换为可比较的格式  const [dayA, monthA, yearA] = a.split('/').map(Number);  const [dayB, monthB, yearB] = b.split('/').map(Number);  const dateA = new Date(yearA, monthA - 1, dayA);  const dateB = new Date(yearB, monthB - 1, dayB);  return dateA.getTime() - dateB.getTime();});let sortedOutputString = '';for (const date of sortedDates) {  sortedOutputString += `----------${date}-------------n`;  groupedData[date].forEach(item => {    sortedOutputString += `${item.category} ${item.time1}n`;  });}console.log(sortedOutputString);

总结

通过本教程,我们学习了如何使用JavaScript的reduce()方法高效地将扁平化的JSON数组按特定字段(如日期)进行分组。接着,我们展示了如何遍历这些分组后的数据,并将其格式化为所需的文本或HTML输出。掌握这种数据处理技巧对于构建动态和用户友好的前端界面至关重要。

以上就是JavaScript:将JSON数组按日期分组并格式化输出到HTML的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/743344.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 16:27:41
下一篇 2025年11月25日 16:28:02

相关推荐

  • 火币(Huobi)交易所APP v10.56.0 最新版本入口

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 火币(Huobi)是一款全球领先的数字资产服务平台,为用户提供广泛的加密货币交易、投资及资产管理服务。其APP以安全稳定、功能全面和操作便捷而著称,是众多数字资产爱…

    2025年12月8日
    000
  • 欧亿交易所官网..交易所app官方

    欧亿交易所(OKX)是全球领先的加密资产交易平台,提供币币、合约等多种交易产品。其核心优势包括:1. 全球化服务网络,覆盖多国市场并支持多语言;2. 丰富的产品矩阵,涵盖现货、期货、期权等多种交易模式;3. 顶级安全防护,采用多重签名冷账户及全面风控系统。用户应通过官网下载应用,并启用双重验证、设置…

    2025年12月8日
    000
  • 大额USDT出金怎样最安全?OTC交易有哪些必须避开的坑?

    数字资产交易日益普及,但大额usdt出金涉及的资金安全与otc(场外交易)风险不容忽视。在进行大额usdt兑换法币时,了解并规避潜在风险至关重要,以确保资产安全并避免不必要的法律纠纷。 大额USDT安全出金核心策略 在处理大额USDT出金时,采取审慎的策略是保护个人资产的关键。以下是一些重要的操作建…

    2025年12月8日
    000
  • okb官网下载地址 okb交易APP官方v6.125.1下载安装地址

    下面是根据您提供的标题生成的下载安装教程,该教程介绍了okb交易app并提供了官方下载链接。请您点击本文提供的下载链接即可下载该应用。 OKB交易APP介绍 OKB交易APP是一款专业的数字资产交易应用,为用户提供便捷、安全的数字资产交易服务。该应用界面简洁,操作流畅,功能全面,支持多种数字资产的交…

    2025年12月8日
    000
  • 如何安装必安App_B安平台v2.120.0官方最新版安全获取

    要安全获取币安App最新版本,必须通过官网或授权应用商店下载;1.访问币安官网;2.在首页找到下载入口;3.选择对应安卓APK或iOS跳转App Store安装;同时需注意非官方渠道存在恶意软件、账户信息窃取等风险,而官方渠道可确保版本原始性与安全性;此外,及时更新至v2.120.0等最新版本可获得…

    2025年12月8日
    000
  • 大额出金最稳操作指南,如何拆分转账才不会被银行冻结?

    加密货币市场交易日益频繁,不少用户在将大额资金从交易所提现到银行卡时,常遇到银行风控审查乃至账户冻结的困扰。理解银行的监管逻辑,并采取合理的转账策略,是确保资金安全到账的关键。以下内容将提供一些稳健的操作方法,旨在帮助用户有效规避潜在风险。 银行风控的考量点 银行对于大额或异常资金流动的监控,是其反…

    2025年12月8日
    000
  • 币安交易所APP官网 币安数字货币交易平台官方入口

    币安(binance)作为全球领先的数字货币交易平台,为用户提供了一个安全、稳定、高效的交易环境。币安app是您随时随地进行加密资产交易、管理和投资的得力助手,涵盖了丰富的交易对和多样的金融产品。为了确保您下载到的是官方正版app,本文提供官方app下载链接。点击本文中对应的下载链接即可快速获取币安…

    2025年12月8日
    000
  • 智能合约风险vs平台跑路,如何平衡收益与风险?

    在数字资产和区块链的世界里,潜在的高收益总是伴随着显著的风险。投资者在追求回报的同时,必须清醒地认识并应对这些风险。其中两大类风险尤为突出:一类是技术层面的智能合约风险,另一类是操作及信任层面的平台风险,后者有时表现为平台运营者“跑路”。理解并平衡这两类风险,是数字资产投资中的重要课题。 智能合约中…

    2025年12月8日
    000
  • 加密货币杠杆代币是什么?3倍多空怎么操作?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 加密货币杠杆代币是一种特殊类型的交易产品,旨在让投资者获得基础资产(如比特币、以太坊等)的杠杆化回报,而无需直接管理保证金、借贷或清算风险。这些代币通常会追踪基础资…

    2025年12月8日
    000
  • 区块链零知识证明是啥?zk-SNARKs怎么工作?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 区块链技术的核心在于透明和分布式记账,但这种透明性有时也会带来隐私问题。零知识证明是一种密码学工具,它允许一方(证明者)向另一方(验证者)证明某个陈述是真实的,而无…

    2025年12月8日
    000
  • 币圈插针是什么意思?为什么突然暴跌又拉回?异常波动解析

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 在加密货币交易市场中,“插针”是一种常见的 K 线图现象。它指的是价格在极短的时间内,出现了一次非常剧烈的下跌或上涨,随后又迅速反弹回原先的价位附近,最终在图表上留…

    2025年12月8日
    000
  • 元宇宙和区块链什么关系?元宇宙是骗局吗?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 元宇宙通常被描述为一个持久的、沉浸式的虚拟环境集合,用户可以在其中进行社交、工作、娱乐和交易。它并非由单一实体控制,而是由众多不同的虚拟世界和平台组成。人们通过虚拟…

    2025年12月8日
    000
  • 币圈黑话有哪些?什么是FOMO和FUD?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 币圈,即加密货币交易社区,拥有其独特的语言体系和俚语,这些术语反映了市场的特性、参与者的情绪以及交易行为。了解这些黑话,是理解币圈文化和交流方式的基础。 币圈黑话一…

    2025年12月8日
    000
  • 稳定币的发行机制是怎样的?

    稳定币看行情交易平台: 欧易OKX: Binance币安: 火币Huobi: Gateio芝麻开门: 稳定币主要通过锚定特定资产或依靠算法来维持价值稳定,常见的发行机制有法币抵押、加密资产抵押和算法控制三种。具体如下: 法币抵押型:以美元等法币为储备,发行方每发行 1 枚稳定币,需在银行或其他金融机…

    好文分享 2025年12月8日
    000
  • 稳定币为什么稳定?稳定币真的不会跌吗?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 稳定币的设计宗旨是维持其市场价值与某一相对稳定的资产(如美元、黄金等)挂钩。人们期待稳定币能够提供加密货币的便利性,同时规避其价格的剧烈波动性。这种稳定性对于交易、…

    2025年12月8日
    000
  • 币圈量化交易是什么?量化交易能赚钱吗?量化交易最直白讲解

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 币圈量化交易,用最简单的话来说,就是利用数学模型和计算机程序来进行加密货币交易的一种方法。它不像人工交易那样依赖交易者的直觉或情绪,而是基于历史数据和预设的规则,通…

    2025年12月8日
    000
  • 币安Binance交易所登录最新地址 币安Binance官网官方页面

    作为全球领先的数字资产交易平台之一,币安binance提供了一个安全、稳定、高效的交易环境。通过币安的官方app,用户可以随时随地进行币种交易、资产管理等操作,享受便捷的服务。本文将详细介绍如何下载和安装币安binance官方app,并提供官方下载链接,点击本文提供的下载链接即可开始下载。币安官网网…

    2025年12月8日
    000
  • 虚拟币交易平台官方最新版 v6.129.0 安卓app2025年新版

    虚拟币交易平台官方最新版 v6.129.0 是一款为安卓用户打造的专业、安全的数字资产交易应用。它提供了丰富的市场行情、便捷的交易功能和多重安全防护,致力于为用户提供一流的交易体验。本文将为您提供2025年新版官方app下载链接,并附上详细的安装说明。点击本文中提供的下载链接,即可下载官方正版应用。…

    2025年12月8日
    000
  • 币圈合约100倍杠杆风险大吗?多少倍最合理?

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 加密货币市场的合约交易,通过引入杠杆机制,极大地放大了投资者的潜在收益。然而,杠杆本身是一把双刃剑,尤其是在波动剧烈的币圈。100倍杠杆意味着投资者可以用1单位的自…

    2025年12月8日
    000
  • 去中心化交易所安全吗?DEX和CEX有什么区别?DEX新手入门指南

    binance币安交易所 注册入口: APP下载: 欧易OKX交易所 注册入口: APP下载: 火币交易所: 注册入口: APP下载: 去中心化交易所(DEX)近年来在加密货币领域受到关注。与传统中心化交易所(CEX)不同,DEX在区块链上运行,旨在提供一种无需信任中介的交易方式。用户在DEX上交易…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信