0

0

JavaScript实现关键字高亮功能_基础知识

php中文网

php中文网

发布时间:2016-05-16 16:31:35

|

2034人浏览过

|

来源于php中文网

原创

高亮功能主要是指对页面中指定区域的指定文字进行高亮显示,也就是背景着色。一般在搜索结果页面会经常用到这个功能。

下面就为大家提供一种解决方案,用javascript实现。

首先在

中引入下面javascript方法:

复制代码 代码如下:

<script type="text/javascript"><br> //<![CDATA[ <br>     //--------begin function fHl(o, flag, rndColor, url)------------------// <br>     function fHl(o, flag, rndColor, url){ <br>         /// <summary><br>         ///     使用 javascript HTML DOM 高亮显示页面特定字词.<br>         ///     实例:<br>         ///         fHl(document.body, '纸伞|她'); <br>         ///         这里的body是指高亮body里面的内容。<br>         ///         fHl(document.body, '希望|愁怨', false, '/'); <br>         ///         fHl(document.getElementById('at_main'), '独自|飘过|悠长', true, 'search.asp?keyword='); <br>         ///         这里的'at_main'是指高亮id='at_main'的div里面的内容。search.asp?keyword=指给关键字加的链接地址,<br>         ///         我这里加了一个参数,在后面要用到。可以是任意的地址。        <br>         /// <br>         /// <param name="o" type="Object"><br>         ///     对象, 要进行高亮显示的对象. <br>         /// <br>         /// <param name="flag" type="String"><br>         ///     字符串, 要进行高亮的词或多个词, 使用 竖杠(|) 分隔多个词 . <br>         /// <br>         /// <param name="rndColor" type="Boolean"><br>         ///     布尔值, 是否随机显示文字背景色与文字颜色, true 表示随机显示. <br>         /// <br>         /// <param name="url" type="String"><br>         ///     URI, 是否对高亮的词添加链接.<br>         ///                         <br>         /// <return><br>         var bgCor=fgCor=''; <br>         if(rndColor){ <br>             bgCor=fRndCor(10, 20); <br>             fgCor=fRndCor(230, 255); <br>         } else { <br>             bgCor='#F0F'; <br>             fgCor='black'; <br>         } <br>         var re=new RegExp(flag, 'i'); <br>         for(var i=0; i<o.childNodes.length; i++){     <br>             var o_=o.childNodes[i]; <br>             var o_p=o_.parentNode; <br>             if(o_.nodeType==1) { <br>                 fHl(o_, flag, rndColor, url);                 <br>              } else if (o_.nodeType==3) { <br>                 if(!(o_p.nodeName=='A')){ <br>                     if(o_.data.search(re)==-1)continue; <br>                     var temp=fEleA(o_.data, flag); <br>                     o_p.replaceChild(temp, o_); <br>                 } <br>             }<br>         } <br>         //------------------------------------------------ <br>         function fEleA(text, flag){ <br>             var style=' style="background-color:'+bgCor+';color:'+fgCor+';" ' <br>             var o=document.createElement('span'); <br>             var str=''; <br>             var re=new RegExp('('+flag+')', 'gi'); <br>             if(url){ <br>                 str=text.replace(re, '<a href="'+url+ <br>                 '$1"'+style+'>$1'); //这里是给关键字加链接,红色的$1是指上面链接地址后的具体参数。<br>             } else { <br>                 str=text.replace(re, '<span '+style+'>$1'); //不加链接时显示<br>             } <br>             o.innerHTML=str; <br>             return o; <br>         } <br>         //------------------------------------------------ <br>         function fRndCor(under, over){ <br>             if(arguments.length==1){ <br>                 var over=under; <br>                     under=0; <br>             }else if(arguments.length==0){ <br>                 var under=0; <br>                 var over=255; <br>             } <br>             var r=fRandomBy(under, over).toString(16); <br>                 r=padNum(r, r, 2); <br>             var g=fRandomBy(under, over).toString(16); <br>                 g=padNum(g, g, 2); <br>             var b=fRandomBy(under, over).toString(16); <br>                 b=padNum(b, b, 2); <br>                 //defaultStatus=r+' '+g+' '+b <br>             return '#'+r+g+b; <br>             function fRandomBy(under, over){ <br>                 switch(arguments.length){ <br>                     case 1: return parseInt(Math.random()*under+1); <br>                     case 2: return parseInt(Math.random()*(over-under+1) + under); <br>                     default: return 0; <br>                 } <br>             }<br>             function padNum(str, num, len){ <br>                 var temp='' <br>                 for(var i=0; i<len;temp+=num, i++); <br>                 return temp=(temp+=str).substr(temp.length-len); <br>             } <br>         } <br>     }<br>     //--------end function fHl(o, flag, rndColor, url)--------------------// <br> //]]> <br> </script>

上面的fHl方法就是用来实现高亮的,参数的含义在注释中有写。

立即学习Java免费学习笔记(深入)”;

Luminal
Luminal

用AI以光速清理、转换和分析电子表格

下载

然后在页面最后调用fHl方法,对指定区域指定文字高亮着色,例如:

复制代码 代码如下:

<script type="text/javascript"><br> fHl(document.body, '高亮');   //对页面body的区域中的“高亮”文字背景着色<br> </script>

怎么样,很简单吧~

相关文章

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

智谱清言 - 免费全能的AI助手
智谱清言 - 免费全能的AI助手

智谱清言 - 免费全能的AI助手

相关专题

更多
batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

36

2026.02.25

Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法
Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法

本专题系统整理Steam官网最新可用入口,涵盖网页版登录地址、新用户注册流程、账号登录方法及官方游戏商店访问说明,帮助新手玩家快速进入Steam平台,完成注册登录并管理个人游戏库。

2

2026.02.25

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

0

2026.02.25

Python数据处理流水线与ETL工程实战
Python数据处理流水线与ETL工程实战

本专题聚焦 Python 在数据工程场景下的实际应用,系统讲解 ETL 流程设计、数据抽取与清洗、批处理与增量处理方案,以及数据质量校验与异常处理机制。通过构建完整的数据处理流水线案例,帮助开发者掌握数据工程中的性能优化思路与工程化规范,为后续数据分析与机器学习提供稳定可靠的数据基础。

0

2026.02.25

Java领域驱动设计(DDD)与复杂业务建模实战
Java领域驱动设计(DDD)与复杂业务建模实战

本专题围绕 Java 在复杂业务系统中的建模与架构设计展开,深入讲解领域驱动设计(DDD)的核心思想与落地实践。内容涵盖领域划分、聚合根设计、限界上下文、领域事件、贫血模型与充血模型对比,并结合实际业务案例,讲解如何在 Spring 体系中实现可演进的领域模型架构,帮助开发者应对复杂业务带来的系统演化挑战。

0

2026.02.25

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

18

2026.02.24

Golang 性能优化专题:提升应用效率
Golang 性能优化专题:提升应用效率

《Golang 性能优化专题》聚焦 Go 应用在高并发与大规模服务中的性能问题,从 profiling、内存分配、Goroutine 调度、GC 机制到 I/O 与锁竞争逐层分析。结合真实案例讲解定位瓶颈的方法与优化策略,帮助开发者建立系统化性能调优思维,在保证代码可维护性的同时显著提升服务吞吐与稳定性。

9

2026.02.24

Golang 面试题精选:高频问题与解答
Golang 面试题精选:高频问题与解答

Golang 面试题精选》系统整理企业常见 Go 技术面试问题,覆盖语言基础、并发模型、内存与调度机制、网络编程、工程实践与性能优化等核心知识点。每道题不仅给出答案,还拆解背后的设计原理与考察思路,帮助读者建立完整知识结构,在面试与实际开发中都能更从容应对复杂问题。

5

2026.02.24

Golang 运行与部署实战:从本地到云端
Golang 运行与部署实战:从本地到云端

《Golang 运行与部署实战》围绕 Go 应用从开发完成到稳定上线的完整流程展开,系统讲解编译构建、环境配置、日志与配置管理、容器化部署以及常见运维问题处理。结合真实项目场景,拆解自动化构建与持续部署思路,帮助开发者建立可靠的发布流程,提升服务稳定性与可维护性。

5

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.5万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.1万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号