news 2026/4/16 8:48:22

操作历史 - Cordova 与 OpenHarmony 混合开发实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
操作历史 - Cordova 与 OpenHarmony 混合开发实战

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

📌 模块概述

操作历史模块是MovieTracker应用中用于记录用户操作的功能。系统会记录用户的所有操作,如添加影片、编辑影片、删除影片等。用户可以查看操作历史,了解自己的操作记录,同时可以撤销或重做某些操作。

该模块的主要功能包括:记录操作、查看历史、撤销操作、重做操作、清空历史等。通过Cordova框架与OpenHarmony原生能力的结合,实现了完整的操作历史管理。

操作历史需要处理大量的操作记录,同时需要支持撤销和重做功能。

🔗 完整流程

第一步:操作记录

系统在用户执行操作时自动记录操作信息,包括操作类型、操作对象、操作时间等。记录过程需要异步进行,避免影响用户体验。

操作记录需要存储在数据库中,支持后续的查询和分析。

第二步:历史查看

用户可以查看所有的操作历史,按时间倒序排列。历史列表需要显示操作的类型、对象、时间等信息。

用户可以搜索和筛选历史记录,快速找到特定的操作。

第三步:撤销与重做

用户可以撤销最近的操作,系统会恢复到操作前的状态。同时支持重做操作,用户可以重新执行撤销的操作。

撤销和重做需要维护一个操作栈,记录所有的操作和状态变化。

🔧 Web代码实现

操作历史HTML结构

<divid="history-page"class="page"><divclass="page-header"><h2>操作历史</h2><divclass="history-actions"><buttonclass="btn btn-secondary"onclick="undoLastOperation()"id="undo-btn">↶ 撤销</button><buttonclass="btn btn-secondary"onclick="redoLastOperation()"id="redo-btn">↷ 重做</button><buttonclass="btn btn-danger"onclick="clearHistory()">🗑️ 清空历史</button></div></div><divclass="history-list"id="history-list"></div></div>

操作历史实现

letoperationHistory=[];lethistoryIndex=-1;asyncfunctionrecordOperation(type,object,details){constoperation={type:type,object:object,details:details,timestamp:Date.now(),id:Date.now()};// 移除重做栈中的操作operationHistory=operationHistory.slice(0,historyIndex+1);operationHistory.push(operation);historyIndex++;// 保存到数据库awaitdb.addHistory(operation);updateHistoryButtons();}asyncfunctionundoLastOperation(){if(historyIndex<0)return;constoperation=operationHistory[historyIndex];historyIndex--;// 执行撤销操作awaitperformUndo(operation);updateHistoryButtons();loadHistoryList();}asyncfunctionredoLastOperation(){if(historyIndex>=operationHistory.length-1)return;historyIndex++;constoperation=operationHistory[historyIndex];// 执行重做操作awaitperformRedo(operation);updateHistoryButtons();loadHistoryList();}asyncfunctionperformUndo(operation){// 根据操作类型执行撤销switch(operation.type){case'add':awaitdb.deleteMovie(operation.object);break;case'delete':awaitdb.addMovie(operation.details);break;case'update':awaitdb.updateMovie(operation.object,operation.details.oldData);break;}}asyncfunctionperformRedo(operation){// 根据操作类型执行重做switch(operation.type){case'add':awaitdb.addMovie(operation.details);break;case'delete':awaitdb.deleteMovie(operation.object);break;case'update':awaitdb.updateMovie(operation.object,operation.details.newData);break;}}functionupdateHistoryButtons(){document.getElementById('undo-btn').disabled=historyIndex<0;document.getElementById('redo-btn').disabled=historyIndex>=operationHistory.length-1;}asyncfunctionloadHistoryList(){try{consthistory=awaitdb.getHistory();renderHistoryList(history);}catch(error){console.error('加载历史失败:',error);}}functionrenderHistoryList(history){constcontainer=document.getElementById('history-list');container.innerHTML='';if(history.length===0){container.innerHTML='<p class="empty-message">暂无操作历史</p>';return;}history.reverse().forEach(op=>{constitem=document.createElement('div');item.className='history-item';constdate=newDate(op.timestamp).toLocaleString('zh-CN');consttypeText={'add':'添加','delete':'删除','update':'修改'}[op.type]||op.type;item.innerHTML=`<span class="operation-type">${typeText}</span> <span class="operation-object">${op.object}</span> <span class="operation-time">${date}</span>`;container.appendChild(item);});}asyncfunctionclearHistory(){if(confirm('确定要清空操作历史吗?')){try{awaitdb.clearHistory();operationHistory=[];historyIndex=-1;loadHistoryList();updateHistoryButtons();showSuccess('历史已清空');}catch(error){console.error('清空历史失败:',error);showError('清空历史失败');}}}

🔌 OpenHarmony原生代码

操作历史插件

// HistoryPlugin.etsimport{webview}from'@kit.ArkWeb';import{common}from'@kit.AbilityKit';exportclassHistoryPlugin{privatecontext:common.UIAbilityContext;constructor(context:common.UIAbilityContext){this.context=context;}publicregisterHistory(controller:webview.WebviewController):void{controller.registerJavaScriptProxy({object:newHistoryBridge(),name:'historyNative',methodList:['recordOperation','getOperationStats']});}}exportclassHistoryBridge{publicrecordOperation(operationJson:string):string{try{constoperation=JSON.parse(operationJson);returnJSON.stringify({success:true,operationId:operation.id,timestamp:operation.timestamp});}catch(error){returnJSON.stringify({success:false,error:error.message});}}publicgetOperationStats(historyJson:string):string{try{consthistory=JSON.parse(historyJson);conststats={totalCount:history.length,addCount:history.filter((h:any)=>h.type==='add').length,deleteCount:history.filter((h:any)=>h.type==='delete').length,updateCount:history.filter((h:any)=>h.type==='update').length};returnJSON.stringify(stats);}catch(error){returnJSON.stringify({error:error.message});}}}

📝 总结

操作历史模块展示了Cordova与OpenHarmony混合开发中的操作记录和撤销重做功能。通过Web层提供历史查看界面,同时利用OpenHarmony原生能力进行操作统计。

在实现这个模块时,需要注意操作记录的完整性、撤销重做的准确性、以及性能的优化。通过合理的架构设计,可以构建出高效、易用的操作历史功能。

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

LangFlow中的拼写检查节点:避免低级错误影响体验

LangFlow 中的拼写检查节点&#xff1a;细节决定 AI 体验的成败 在构建大语言模型&#xff08;LLM&#xff09;应用时&#xff0c;我们往往把注意力集中在模型选型、提示工程、向量数据库优化等“高阶”技术上。然而&#xff0c;在真实用户场景中&#xff0c;一个最不起眼的拼写…

作者头像 李华
网站建设 2026/4/10 0:40:02

LangFlow与员工培训结合:个性化学习内容推荐

LangFlow与员工培训结合&#xff1a;个性化学习内容推荐 在企业人才发展的战场上&#xff0c;一场静悄悄的变革正在发生。传统的“统一课件集中授课”模式正逐渐让位于更加智能、灵活的自适应学习系统。而在这场转型中&#xff0c;一个名为 LangFlow 的可视化工具&#xff0c;正…

作者头像 李华
网站建设 2026/4/11 15:47:56

LangFlow中的法律条款生成器:合同文书快速起草

LangFlow中的法律条款生成器&#xff1a;合同文书快速起草 在企业日常运营中&#xff0c;一份技术服务合同的初稿往往需要法务人员反复查阅模板、核对条款、调整措辞&#xff0c;耗时动辄数小时。而如今&#xff0c;借助AI工具&#xff0c;这一过程可以被压缩到几分钟——只需填…

作者头像 李华
网站建设 2026/4/14 21:35:36

GIS 数据转换:使用 GDAL 将 TXT 转换为 Shp 数据

前言 ❝ TXT 作为一种文本格式&#xff0c;可以很方便的存储一些简单几何数据。在 GIS 开发中&#xff0c;经常需要进行数据的转换处理&#xff0c;其中常见的便是将 TXT 转换为 Shp 数据进行展示。本篇教程在之前一系列文章的基础上讲解如如果你还没有看过&#xff0c;建议从以…

作者头像 李华
网站建设 2026/4/15 13:03:34

LangFlow中的A/B测试节点:比较不同提示词效果

LangFlow中的A/B测试节点&#xff1a;比较不同提示词效果 在构建基于大语言模型&#xff08;LLM&#xff09;的应用时&#xff0c;一个看似微小的改动——比如把“请解释”换成“你能告诉我吗&#xff1f;”——可能显著影响输出质量。然而&#xff0c;在实际开发中&#xff0c…

作者头像 李华
网站建设 2026/4/8 23:38:46

CANFD协议控制字段功能逐项解读

深入CAN FD控制字段&#xff1a;一位嵌入式工程师的实战解析最近在调试一个ADAS雷达节点时&#xff0c;我遇到了一个奇怪的问题&#xff1a;明明发送的是64字节的数据帧&#xff0c;接收端却只收到了8个字节&#xff0c;还报了CRC错误。花了整整两天排查硬件、示波器抓波形、翻…

作者头像 李华