新闻中心
html如何进行搜索_在HTML页面实现本地搜索功能【搜索】
可在静态HTML中用J*aScript实现本地文本搜索:一、遍历文本节点高亮关键词;二、限定data-searchable区域搜索;三、用mark.js库快速高亮;四、统计结果并滚动定位;五、优化连续搜索与退格清除。

如果您希望在静态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操作中高效处理空数组


2025-12-16
浏览次数:次
返回列表