新闻中心

html如何进行搜索_在HTML页面实现本地搜索功能【搜索】

2025-12-16
浏览次数:
返回列表
可在静态HTML中用J*aScript实现本地文本搜索:一、遍历文本节点高亮关键词;二、限定data-searchable区域搜索;三、用mark.js库快速高亮;四、统计结果并滚动定位;五、优化连续搜索与退格清除。

html如何进行搜索_在html页面实现本地搜索功能【搜索】

如果您希望在静态HTML页面中实现无需服务器支持的本地文本搜索功能,则可以通过J*aScript操作DOM来匹配并高亮页面中的关键词。以下是实现此功能的步骤:

一、使用J*aScript遍历文本节点并高亮匹配内容

该方法通过递归遍历页面所有文本节点,将用户输入的关键词在纯文本中查找,并用标签包裹匹配部分以实现高亮。它不依赖外部库,适用于大多数现代浏览器。

1、在HTML底部添加一个输入框和搜索按钮,例如:

2、定义performSearch()函数:获取id为searchInput的元素值,去除首尾空格,若为空则返回

3、调用clearHighlights()函数清除之前所有高亮标记

4、使用document.body.createTreeWalker()遍历所有文本节点

5、对每个文本节点,使用RegExp匹配关键词(忽略大小写),若匹配成功,则用span标签包裹匹配内容并替换原节点

二、基于data-searchable属性的区域限定搜索

该方法允许仅在指定容器内执行搜索,避免干扰导航栏、页脚等非正文内容。通过为需要参与搜索的元素添加data-searchable="true"属性,提升搜索精准度与性能。

1、给需被搜索的正文区域添加属性,例如:

这里是可搜索的正文内容。

2、在performSearch()中使用document.querySelectorAll('[data-searchable="true"]')获取目标容器集合

3、对每个容器执行文本节点遍历与匹配逻辑,而非全页面遍历

4、匹配时采用正则全局匹配模式g与忽略大小写标志i

5、每次匹配后调用element.normalize()合并相邻文本节点,防止重复包裹

三、使用mark.js第三方库快速实现高亮

mark.js是一个轻量级、专为文本高亮设计的J*aScript库,支持区分大小写、跨标签匹配、自定义高亮标签与CSS类,适合快速集成。

1、在页面

中引入mark.js CDN链接:

2、创建一个Mark实例,传入document.querySelector("body")作为上下文

网博士中英文外贸企业网站源码 网博士中英文外贸企业网站源码

系统简介系统三大特色:1、全静态:全站生成.html静态页面。降低服务器压力,增强百度收录。2、高优化:特别针对搜索引擎进行优化处理,让客户快速找到你。3、够简单:拥有完善后台管理系统,所有内容均可在后台进行更新。非专业人士也可操作。网站后台后台管理地址:http://你的网站域名/Admin/login.asp用户名:admin密码:admin后台文件夹名:Admin数据库存放位置:Data21

网博士中英文外贸企业网站源码 0 查看详情 网博士中英文外贸企业网站源码

3、调用instance.mark()方法,参数为用户输入的关键词字符串

4、通过CSS定义.mark样式,例如设置background-color为#ffeb3b以实现醒目高亮

5、调用instance.unmark()清除已有高亮后再执行新搜索,确保每次搜索结果互不干扰

四、实现搜索结果计数与滚动定位

该方法增强用户体验,显示共找到多少处匹配项,并自动将页面滚动至第一个匹配位置,便于用户快速定位。

1、在performSearch()函数末尾初始化计数器count = 0

2、每次成功替换文本节点时,count加1

3、搜索完成后,将结果数量插入到页面中某元素内,例如document.getElementById("resultCount").textContent = "找到 " + count + " 处"

4、获取第一个被高亮的元素:document.querySelector("mark")或自定义高亮标签

5、对该元素调用scrollIntoView({ beh*ior: 'smooth', block: 'center' })实现平滑居中滚动

五、支持退格清除与连续搜索优化

该方法解决多次搜索时残留标记、重复包裹、性能下降等问题,通过监听输入事件与节流机制提升响应效率。

1、为搜索输入框绑定input事件,而非仅依赖按钮点击

2、使用setTimeout与clearTimeout实现简单节流,延迟300ms执行搜索,避免频繁触发

3、当用户清空输入框时,立即调用clearHighlights()并重置结果计数

4、在高亮前检查当前节点是否已包含嵌套的高亮标签,跳过已处理节点

5、使用Node.replaceChild()替代innerHTML重写,避免表单控件状态丢失与事件监听器解绑

以上就是html如何进行搜索_在HTML页面实现本地搜索功能【搜索】的详细内容,更多请关注其它相关文章!


# javascript  # css  # 关键词  # cdn  # 浏览器  # node  # js  # html  # java  # 网站优化三条原则包括  # 河源口碑营销推广  # 网站建设推广刺盾云工具  # 松岗关键词排名  # 新闻广角网站建设方案  # 网络营销推广获客多少钱  # 美容网站建设美丽中国  # 哪里建设网站公司好  # 日喀则310seo  # 重庆网站的优化排名  # 搜索结果  # 自定义  # 输入框  # 换行  # 搜索功能  # 企业网站  # 表单  # 递归  # 遍历 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 京东单号查询入口_京东快递订单追踪入口  Golang切片为何属于引用类型_Golang slice底层结构与引用语义说明  处理Kafka消费者会话超时:深入理解消息处理语义与幂等性  蛙漫官网漫画入口地址_蛙漫在线畅读无广告弹窗  PySpark中从现有列右侧提取可变长度字符创建新列的教程  如何在低配置电脑上搭建轻量级J*a环境_占用更小的环境选择技巧  俄罗斯方块最新版入口 俄罗斯方块在线玩官网入口  Log4j Console Appender性能瓶颈与高并发优化策略  淘宝支付提示失败如何解决 淘宝支付流程优化方法  漫蛙Manwa2官网入口地址分享 漫蛙漫画PC版永久访问通道  word邮件合并后日期格式不对怎么改_Word邮件合并日期格式修改方法  PHP高效扁平化嵌套数组:使用array_merge与数组解包操作符  如何提高微信支付的安全性_微信支付安全防护与设置建议  神经网络二分类模型训练异常:高损失与完美验证准确率的排查与修正  css链接悬停下划线样式如何自定义_使用::after结合content和transition  ArrayList与LinkedList操作复杂度详解:遍历与修改  TypeScript/J*aScript:高效查找数组中首个唯一ID对象  钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧  Typer应用中动态命令行参数的解析与处理  Python中高效访问嵌套字典与列表中的键值对  c++如何实现一个简单的软件渲染器_c++从零开始的3D图形学  msn官网入口地址手机版 msn官方网站手机最新链接  支付宝碰一碰设备是REDMI手机吗 博主拆机辟谣:处理器、内存都不一样  向日葵客户端怎么进行远程CentOS控制_向日葵客户端远程CentOS控制操作教程  探索高级语言到原生C/C++的转译:挑战与内存管理策略  163邮箱登录密码 163邮箱忘记密码找回  抖音极速版最新版本 抖音极速版官方下载地址  漫蛙manwa2最新登录网址_漫蛙manwa2手机网页版入口  网易大神账号申诉需要多久_网易大神账号申诉流程说明  痛风发作了怎么办? 快速止痛和后期饮食调理  蛙漫漫画官网在线入口 蛙漫全本漫画免费阅读平台  夸克浏览器图书入口 夸克手机浏览器阅读入口  在J*a中如何使用BigDecimal进行高精度计算_BigDecimal类应用指南  学习通网页版快速入口 学习通官网网页版直接打开  uc浏览器网页版极速入口 uc网页浏览器网页版流畅体验  一加手机拍照效果不好怎么办 一加哈苏影像调校与专业模式使用教程【高手篇】  单射、满射与双射的关系 一文理清所有逻辑  C#如何安全地从用户上传的XML文件中读取数据? 验证与清理策略  Composer的 "licenses" 命令如何帮助你遵守开源协议_检查项目依赖的许可证合规性  晋江读书网页版在线登录 晋江读书电脑版官网  Django表单验证失败时保留用户输入数据的最佳实践  电脑屏幕颜色不舒服怎么办_Windows夜间模式与色彩校准教程【护眼技巧】  虫虫漫画精品漫画官网_虫虫漫画精品漫画官网进入精品漫画  在Runstone环境中高效处理TasteDive API的JSON数据  MAC怎么安装Homebrew包管理器_MAC为开发者和高级用户安装命令行工具  Fabric Mod开发:在1.19.3+版本中正确添加自定义物品并管理物品组  PHP中SSG-WSG API的AES加密实践:正确使用初始化向量  C++编译期如何执行复杂计算_C++模板元编程(TMP)技巧与应用  Python字典中优雅地迭代剩余元素的方法  J*aScript:在map操作中高效处理空数组 

搜索