news 2026/3/29 11:11:35

旅行记录应用统计分析 - Cordova OpenHarmony 混合开发实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
旅行记录应用统计分析 - Cordova OpenHarmony 混合开发实战

欢迎大家加入开源鸿蒙跨平台开发者社区,一起共建开源鸿蒙跨平台生态。

📌 概述

统计分析功能提供了旅行数据的深度分析。用户可以查看旅行的统计数据,如总旅行数、总花费、平均花费等。统计分析还支持按目的地、时间等维度进行分析。在 Cordova 与 OpenHarmony 的混合开发框架中,统计分析需要实现复杂的数据计算和可视化。

🔗 完整流程

第一步:数据统计计算

统计分析需要对旅行数据进行各种计算,如求和、平均、最大值、最小值等。计算结果需要按不同维度进行分组和排序。

第二步:统计结果展示与可视化

统计结果可以以表格、图表等形式展示。用户可以选择不同的统计维度和时间范围。

第三步:原生层数据处理与缓存

OpenHarmony 原生层可以实现高性能的数据计算和缓存。原生层还可以实现图表的渲染。

🔧 Web 代码实现

统计分析页面 HTML 结构

<divid="statistics-page"class="page"><divclass="page-header"><h1>统计分析</h1></div><divclass="statistics-container"><divclass="stats-cards"><divclass="stat-card"><spanclass="stat-label">总旅行数</span><spanclass="stat-value"id="totalTrips">0</span></div><divclass="stat-card"><spanclass="stat-label">总花费</span><spanclass="stat-value"id="totalExpense">¥0</span></div><divclass="stat-card"><spanclass="stat-label">平均花费</span><spanclass="stat-value"id="avgExpense">¥0</span></div><divclass="stat-card"><spanclass="stat-label">总天数</span><spanclass="stat-value"id="totalDays">0</span></div></div><divclass="stats-chart"id="statsChart"><!-- 图表动态加载 --></div><divclass="stats-table"id="statsTable"><!-- 统计表格动态加载 --></div></div></div>

HTML 结构包含统计卡片、图表和表格。

加载统计数据函数

asyncfunctionloadStatistics(){try{// 获取所有旅行consttrips=awaitdb.getAllTrips();// 计算统计数据conststats=calculateStatistics(trips);// 更新统计卡片document.getElementById('totalTrips').textContent=stats.totalTrips;document.getElementById('totalExpense').textContent=`¥${stats.totalExpense}`;document.getElementById('avgExpense').textContent=`¥${stats.avgExpense}`;document.getElementById('totalDays').textContent=stats.totalDays;// 渲染统计表格renderStatisticsTable(stats.byDestination);}catch(error){console.error('Error loading statistics:',error);showToast('加载统计数据失败');}}

加载统计数据函数计算统计信息。

统计计算函数

functioncalculateStatistics(trips){lettotalTrips=trips.length;lettotalExpense=0;lettotalDays=0;constbyDestination={};trips.forEach(trip=>{// 累加花费totalExpense+=trip.expense||0;// 计算天数conststartDate=newDate(trip.startDate);constendDate=newDate(trip.endDate);constdays=Math.ceil((endDate-startDate)/(1000*60*60*24))+1;totalDays+=days;// 按目的地分组if(!byDestination[trip.destination]){byDestination[trip.destination]={count:0,expense:0,days:0};}byDestination[trip.destination].count++;byDestination[trip.destination].expense+=trip.expense||0;byDestination[trip.destination].days+=days;});constavgExpense=totalTrips>0?Math.round(totalExpense/totalDays):0;return{totalTrips,totalExpense,avgExpense,totalDays,byDestination};}

统计计算函数计算各种统计指标。

统计表格渲染函数

functionrenderStatisticsTable(byDestination){constcontainer=document.getElementById('statsTable');container.innerHTML='<h3>按目的地统计</h3>';consttable=document.createElement('table');table.className='stats-table';table.innerHTML=`<thead> <tr> <th>目的地</th> <th>次数</th> <th>总花费</th> <th>总天数</th> <th>平均花费</th> </tr> </thead> <tbody>${Object.entries(byDestination).map(([destination,stats])=>`<tr> <td>${destination}</td> <td>${stats.count}</td> <td>¥${stats.expense}</td> <td>${stats.days}</td> <td>¥${Math.round(stats.expense/stats.days)}</td> </tr>`).join('')}</tbody>`;container.appendChild(table);}

统计表格渲染函数展示按目的地的统计数据。

🔌 OpenHarmony 原生代码实现

统计分析插件

// StatisticsPlugin.etsimport{BusinessError}from'@ohos.base';exportclassStatisticsPlugin{// 处理统计数据加载事件onStatisticsLoaded(args:any,callback:Function):void{try{consttripCount=args[0].tripCount;consttotalExpense=args[0].totalExpense;console.log(`[Statistics] Loaded:${tripCount}trips, ¥${totalExpense}`);callback({success:true,message:'统计数据已加载'});}catch(error){callback({success:false,error:error.message});}}}

统计分析插件处理统计数据加载。

📝 总结

统计分析功能展示了如何在 Cordova 与 OpenHarmony 框架中实现一个数据分析系统。Web 层负责统计计算和 UI 展示,原生层负责高性能数据处理。通过统计分析,用户可以深入了解旅行数据。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/24 9:42:07

淘宝购物助手:3大技巧助你提升购物效率,轻松选购心仪好物!

还在为淘宝热门商品总是"库存不足"而烦恼吗&#xff1f;每次看到喜欢的商品很快售罄&#xff0c;那种失落感是不是让你有些无奈&#xff1f;别担心&#xff0c;今天我要分享的淘宝购物助手就是你的好帮手&#xff0c;它能帮你提升购物效率&#xff0c;让你更轻松地选…

作者头像 李华
网站建设 2026/3/26 18:51:00

LangFlow与Redis集成:实现高速数据缓存与共享

LangFlow与Redis集成&#xff1a;实现高速数据缓存与共享 在构建现代AI应用的实践中&#xff0c;一个日益突出的矛盾逐渐显现&#xff1a;开发者渴望快速验证复杂逻辑&#xff0c;而现实却是——每修改一次提示词就得重跑一遍LLM调用&#xff0c;每次测试都伴随着数秒甚至更长的…

作者头像 李华
网站建设 2026/3/28 18:04:12

LangFlow与Excel文件处理:读取、写入与数据分析

LangFlow与Excel文件处理&#xff1a;读取、写入与数据分析 在企业数据仍大量沉淀于Excel表格的今天&#xff0c;如何让大语言模型&#xff08;LLM&#xff09;真正“读懂”这些业务报表&#xff0c;并自动完成分析、摘要甚至决策建议&#xff1f;这不仅是技术挑战&#xff0c;…

作者头像 李华
网站建设 2026/3/26 4:12:34

LangFlow中的绩效评估助手:自动生成评语与建议

LangFlow中的绩效评估助手&#xff1a;自动生成评语与建议 在企业HR的实际工作中&#xff0c;每到季度或年度考核期&#xff0c;撰写员工绩效评语往往成了一项令人头疼的任务。几十甚至上百份评语要逐个打磨&#xff0c;既要体现差异化&#xff0c;又要保持语气一致、结构规范&…

作者头像 李华
网站建设 2026/3/25 6:35:26

LangFlow中的OCR节点:图像文字识别集成方案

LangFlow中的OCR节点&#xff1a;图像文字识别集成方案 在智能应用开发日益复杂的今天&#xff0c;如何快速将现实世界中的非结构化信息——比如一张合同截图、一份扫描版发票或教科书的一页照片——转化为可被大语言模型理解与处理的数据&#xff0c;已成为多模态AI系统构建的…

作者头像 李华
网站建设 2026/3/29 3:52:50

如何安全安装Packet Tracer汉化版(Windows)

如何安全安装 Packet Tracer 汉化版&#xff1a;从零开始的实战指南&#xff08;Windows&#xff09; 你是不是也曾在打开 Cisco Packet Tracer 时&#xff0c;面对满屏英文菜单感到头大&#xff1f;尤其是刚接触网络技术的新手&#xff0c;“Static Route”“Subnet Mask”这…

作者头像 李华