news 2026/4/23 12:19:27

旅行记录应用筛选器管理 - Cordova OpenHarmony 混合开发实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
旅行记录应用筛选器管理 - Cordova OpenHarmony 混合开发实战

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

📌 概述

筛选器管理功能允许用户保存和管理自定义的搜索筛选条件。用户可以创建多个筛选器,快速应用预定义的搜索条件。筛选器管理提供了快速访问常用搜索的便利。在 Cordova 与 OpenHarmony 的混合开发框架中,筛选器管理需要实现筛选器的保存、加载和应用功能。

🔗 完整流程

第一步:筛选器数据模型设计

筛选器需要保存用户的搜索条件,包括目的地、日期范围、花费范围、标签等。筛选器需要有名称和描述,便于用户识别。筛选器还需要记录创建时间和最后使用时间。

第二步:筛选器列表展示与操作

筛选器管理页面需要展示所有保存的筛选器。用户可以查看筛选器的详细信息,也可以进行编辑、删除、应用等操作。筛选器可以按名称、最后使用时间等进行排序。

第三步:原生层筛选器缓存与快速应用

OpenHarmony 原生层可以缓存常用的筛选器,提高应用速度。原生层还可以实现筛选器的快速应用,减少计算时间。

🔧 Web 代码实现

筛选器管理页面 HTML 结构

<divid="filters-page"class="page"><divclass="page-header"><h1>筛选器管理</h1><buttonclass="btn btn-primary"onclick="openFilterModal()">➕ 新建筛选器</button></div><divclass="filters-container"><divclass="filters-list"id="filtersList"><!-- 筛选器列表动态加载 --></div></div></div>

HTML 结构包含筛选器列表和新建筛选器按钮。

加载筛选器列表函数

asyncfunctionloadFilters(){try{// 从数据库查询所有筛选器constfilters=awaitdb.getAllFilters();// 按最后使用时间排序filters.sort((a,b)=>{consttimeA=a.lastUsedAt?newDate(a.lastUsedAt).getTime():0;consttimeB=b.lastUsedAt?newDate(b.lastUsedAt).getTime():0;returntimeB-timeA;});// 渲染筛选器列表renderFiltersList(filters);}catch(error){console.error('Error loading filters:',error);showToast('加载筛选器失败');}}

这个函数从数据库查询所有筛选器,按最后使用时间排序。loadFilters 函数是筛选器管理的核心加载函数。函数首先从数据库获取所有保存的筛选器。然后按照最后使用时间进行降序排序,使得最近使用的筛选器显示在最前面,方便用户快速访问常用的筛选器。如果筛选器没有使用过,则使用时间为 0,这样的筛选器会显示在列表的最后。最后调用 renderFiltersList 函数将排序后的筛选器列表渲染到页面上。这种设计提高了用户的工作效率,用户可以快速找到常用的筛选器。

筛选器列表渲染函数

functionrenderFiltersList(filters){constcontainer=document.getElementById('filtersList');container.innerHTML='';filters.forEach(filter=>{constfilterElement=document.createElement('div');filterElement.className='filter-item';filterElement.id=`filter-${filter.id}`;filterElement.innerHTML=`<div class="filter-header"> <h3>${filter.name}</h3> <span class="filter-count">${filter.usageCount||0}次使用</span> </div> <div class="filter-body"> <p class="filter-description">${filter.description||'暂无描述'}</p> <div class="filter-criteria">${filter.destination?`<span>📍${filter.destination}</span>`:''}${filter.minExpense?`<span>💰 ¥${filter.minExpense}-${filter.maxExpense}</span>`:''}</div> </div> <div class="filter-footer"> <button class="btn-small" onclick="applyFilter(${filter.id})"> 应用 </button> <button class="btn-small" onclick="editFilter(${filter.id})"> 编辑 </button> <button class="btn-small btn-danger" onclick="deleteFilter(${filter.id})"> 删除 </button> </div>`;container.appendChild(filterElement);});}

筛选器列表渲染函数为每个筛选器创建一个 DOM 元素。

保存筛选器函数

asyncfunctionsaveFilter(filterData){try{// 验证数据if(!filterData.name||filterData.name.trim()===''){showToast('筛选器名称不能为空');return;}// 创建筛选器对象constfilter={id:filterData.id||Date.now(),name:filterData.name,description:filterData.description,destination:filterData.destination,startDate:filterData.startDate,endDate:filterData.endDate,minExpense:filterData.minExpense,maxExpense:filterData.maxExpense,tags:filterData.tags,createdAt:filterData.createdAt||newDate().toISOString(),updatedAt:newDate().toISOString(),usageCount:filterData.usageCount||0};// 保存到数据库if(filterData.id){awaitdb.updateFilter(filter);showToast('筛选器已更新');}else{awaitdb.addFilter(filter);showToast('筛选器已创建');}// 关闭模态框closeModal();// 重新加载列表loadFilters();// 通知原生层if(window.cordova){cordova.exec((result)=>console.log('Filter saved:',result),(error)=>console.error('Save error:',error),'FilterPlugin','onFilterSaved',[{filterId:filter.id,timestamp:Date.now()}]);}}catch(error){console.error('Error saving filter:',error);showToast('保存失败,请重试');}}

保存筛选器函数创建或更新筛选器,然后保存到数据库。

应用筛选器函数

asyncfunctionapplyFilter(filterId){try{// 获取筛选器数据constfilter=awaitdb.getFilter(filterId);if(filter){// 更新使用次数filter.usageCount=(filter.usageCount||0)+1;filter.lastUsedAt=newDate().toISOString();awaitdb.updateFilter(filter);// 应用筛选器条件constallTrips=awaitdb.getAllTrips();constresults=filterTrips(allTrips,{destination:filter.destination,startDate:filter.startDate,endDate:filter.endDate,minExpense:filter.minExpense,maxExpense:filter.maxExpense,tags:filter.tags});// 导航到搜索结果页面navigateTo('search-results',{results:results});showToast(`已应用筛选器:${filter.name}`);}}catch(error){console.error('Error applying filter:',error);showToast('应用筛选器失败');}}

应用筛选器函数使用保存的筛选器条件进行搜索。

删除筛选器函数

asyncfunctiondeleteFilter(filterId){if(!confirm('确定要删除这个筛选器吗?')){return;}try{// 从数据库删除awaitdb.deleteFilter(filterId);showToast('筛选器已删除');// 从列表移除constelement=document.getElementById(`filter-${filterId}`);if(element){element.remove();}// 通知原生层if(window.cordova){cordova.exec((result)=>console.log('Filter deleted:',result),(error)=>console.error('Delete error:',error),'FilterPlugin','onFilterDeleted',[{filterId:filterId,timestamp:Date.now()}]);}}catch(error){console.error('Error deleting filter:',error);showToast('删除失败,请重试');}}

删除筛选器函数从数据库中删除筛选器。

🔌 OpenHarmony 原生代码实现

筛选器缓存插件

// FilterPlugin.etsimport{BusinessError}from'@ohos.base';exportclassFilterPlugin{privatefilterCache:Map<number,any>=newMap();// 处理筛选器保存事件onFilterSaved(args:any,callback:Function):void{try{constfilterId=args[0].filterId;consttimestamp=args[0].timestamp;// 清除缓存this.filterCache.clear();console.log(`[Filter] Saved:${filterId}at${timestamp}`);callback({success:true,message:'筛选器已保存'});}catch(error){callback({success:false,error:error.message});}}// 处理筛选器删除事件onFilterDeleted(args:any,callback:Function):void{try{constfilterId=args[0].filterId;// 清除缓存this.filterCache.delete(filterId);console.log(`[Filter] Deleted:${filterId}`);callback({success:true,message:'筛选器已删除'});}catch(error){callback({success:false,error:error.message});}}}

筛选器缓存插件在原生层管理筛选器缓存。

📝 总结

筛选器管理功能展示了如何在 Cordova 与 OpenHarmony 框架中实现一个筛选器保存和应用系统。Web 层负责 UI 渲染和筛选器操作,原生层负责缓存管理。通过筛选器管理,用户可以快速应用常用的搜索条件。

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

10 个AI论文工具,助力继续教育学员高效写作!

10 个AI论文工具&#xff0c;助力继续教育学员高效写作&#xff01; AI 工具的崛起&#xff0c;让学术写作更高效 在当前继续教育的背景下&#xff0c;越来越多的学员需要面对论文写作这一重要任务。无论是本科、硕士还是博士阶段&#xff0c;论文的撰写都是一项耗时且复杂的工…

作者头像 李华
网站建设 2026/4/23 10:48:27

Flutter:构建高性能跨平台应用的现代框架

标题&#xff1a;Flutter&#xff1a;构建高性能跨平台应用的现代框架 引言 在移动应用开发领域&#xff0c;开发者始终面临一个核心挑战&#xff1a;如何以最少的资源和时间&#xff0c;为多个平台&#xff08;如 iOS 和 Android&#xff09;构建高质量、一致体验的应用。传统…

作者头像 李华
网站建设 2026/4/17 9:21:08

深入理解Go语言errors.As方法:灵活的错误类型识别

引言 在Go语言中&#xff0c;错误处理是一个核心话题。Go 1.13引入了新的错误处理机制&#xff0c;包括错误包裹&#xff08;error wrapping&#xff09;和几个相关的工具函数。其中errors.As函数是一个非常有用但可能被忽视的工具&#xff0c;它允许我们在错误链中查找特定类型…

作者头像 李华
网站建设 2026/4/23 12:14:59

9个AI论文工具,自考本科轻松搞定!

9个AI论文工具&#xff0c;自考本科轻松搞定&#xff01; AI 工具如何助力自考论文写作 在当前的学术环境中&#xff0c;越来越多的学生开始借助 AI 工具来提升论文写作效率。对于自考生而言&#xff0c;时间紧张、任务繁重是常态&#xff0c;而 AI 工具的出现则为他们提供了强…

作者头像 李华
网站建设 2026/4/18 9:40:40

Redis 如何应对大数据高并发访问挑战

Redis如何应对大数据高并发访问挑战&#xff1a;从原理到实践的深度解析 摘要 在电商秒杀、实时推荐、分布式缓存等高并发场景中&#xff0c;传统关系型数据库&#xff08;如MySQL&#xff09;因磁盘IO瓶颈、连接数限制等问题&#xff0c;无法满足每秒数万甚至数十万次的请求需…

作者头像 李华
网站建设 2026/3/27 15:06:29

Java线程的三种创建方式

目录 1.线程的概念 2.进程和线程的对比 3.线程创建的三种方式 1)继承Thread类 2)实现Runnable接口 3)实现Callable接口 三种方法的执行流程 1.线程的概念 线程是程序执行流的最小单位&#xff0c;是进程中的一个独立执行单元。一个进程可以包含多个线程&#xff0c;这些…

作者头像 李华