高亮关键字(javascript+html)

使用时传递要高亮的关键字如: XXX.htm?key=杜川 
可为关键字加链接
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" " http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns=" http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>shawl.qiu template</title> 
<SCRIPT LANGUAGE="JavaScript"> 
<!-- 
function Request(strName) 
{ 
var strHref = window.document.location.href; 
var intPos = strHref.indexOf("?"); 
var strRight = strHref.substr(intPos + 1); 

var arrTmp = strRight.split("&"); 
for(var i = 0; i < arrTmp.length; i++) 
{ 
var arrTemp = arrTmp[i].split("="); 

if(arrTemp[0].toUpperCase() == strName.toUpperCase()) return arrTemp[1]; 
} 
return ""; 
} 
//参数
var keyword=Request("key"); 
//document.write(id); 
//--> 
</SCRIPT>
<script type="text/javascript"> 
//<![CDATA[ 
    οnlοad=function(){ 
        fHl(document.body, keyword); 
       // fHl(document.body, '丁香|雨巷', true); 
         
      //  fHl(document.body, '希望|愁怨', false, '/'); 
       // fHl(document.getElementById('at_main'), '独自|飘过|悠长', true, '/'); 
		 fHl(document.body, keyword, false, 'http://dcdc723.iteye.com?key='+keyword);
		 // fEleA(document.body,'kt');
         
/*         fHl(document.body, '纸伞'); 
        fHl(document.body, '她', false, '/'); 
        fHl(document.body, '丁香', true, '/'); 
        fHl(document.body, '雨巷', true, '/'); 
         
        fHl(document.body, '希望', false); 
        fHl(document.body, '愁怨', true); */ 
         
/*         fHl(document.body, '丁香', 'blue', 'white', '/'); 
        fHl(document.body, '雨巷', 'gray', 'white', '/'); 
        fHl(document.body, '独自', 'white', 'red'); 
        fHl(document.body, '悠长', 'white', 'red'); 
        fHl(document.body, '飘过'); */ 
    } 
    /*----------------------------------------*\ 
     * 使用 javascript HTML DOM 高亮显示页面特定字词 By shawl.qiu 
     * 参数说明: 
     * o: 对象, 要进行高亮显示的对象. 
     * flag: 字符串, 要进行高亮的词或多个词, 使用 竖杠(|) 分隔多个词 . 
     * rndColor: 布尔值, 是否随机显示文字背景色与文字颜色, true 表示随机显示. 
     * url: URI, 是否对高亮的词添加链接.  
    \*----------------------------------------*/ 
    //--------begin function fHl(o, flag, rndColor, url)------------------// 
    function fHl(o, flag, rndColor, url){ 
        var bgCor=fgCor=''; 
        if(rndColor){ 
            bgCor=fRndCor(10, 20); 
            fgCor=fRndCor(230, 255); 
        } else { 
            bgCor='yellow'; 
            fgCor='black'; 
        } 
        var re=new RegExp(flag, 'i'); 
        for(var i=0; i<o.childNodes.length; i++){     
            var o_=o.childNodes[i]; 
            var o_p=o_.parentNode; 
            if(o_.nodeType==1) { 
                fHl(o_, flag, rndColor, url);                 
             } else if (o_.nodeType==3) { 
                if(!(o_p.nodeName=='A')){ 
                    if(o_.data.search(re)==-1)continue; 
                    var temp=fEleA(o_.data, flag); 
                    o_p.replaceChild(temp, o_); 
                } 
            }  // shawl.qiu script 
        } 
		
        //------------------------------------------------ 
        function fEleA(text, flag){ 
            var style=' style="background-color:'+bgCor+';color:'+fgCor+';" ' 
            var o=document.createElement('span'); 
            var str=''; 
            var re=new RegExp('('+flag+')', 'gi'); 
            if(url){ 
                str=text.replace(re, '<a href="'+url+'"'+style+'>$1</a>'); 
            } else { 
                str=text.replace(re, '<span '+style+'>$1</span>'); 
            } 
            o.innerHTML=str; 
            return o; 
        }     // shawl.qiu script 
        //------------------------------------------------ 
        function fRndCor(under, over){ 
            if(arguments.length==1){ 
                var over=under; 
                    under=0; 
            }else if(arguments.length==0){ 
                var under=0; 
                var over=255; 
            } 
            var r=fRandomBy(under, over).toString(16); 
                r=padNum(r, r, 2); 
            var g=fRandomBy(under, over).toString(16); 
                g=padNum(g, g, 2); 
            var b=fRandomBy(under, over).toString(16); 
                b=padNum(b, b, 2); 
                //defaultStatus=r+' '+g+' '+b 
            return '#'+r+g+b; 
            function fRandomBy(under, over){ 
                switch(arguments.length){ 
                    case 1: return parseInt(Math.random()*under+1); 
                    case 2: return parseInt(Math.random()*(over-under+1) + under); 
                    default: return 0; 
                } 
            } // shawl.qiu script 
            function padNum(str, num, len){ 
                var temp='' 
                for(var i=0; i<len;temp+=num, i++); 
                return temp=(temp+=str).substr(temp.length-len); 
            } // shawl.qiu script 
        } 
    } // shawl.qiu script 
    //--------end function fHl(o, flag, rndColor, url)--------------------// 
//]]> 
</script> 
</head> 
<body> 
<div class="at_main" id="at_main"><p/><b>CITE:</b><cite><div class=u_cite>戴望舒写女孩<br/> 
<br/> 杜川杜川杜川杜川杜川杜川杜川杜川杜川杜川杜  杜川川杜川kt1 川1杜川
&nbsp;雨  巷&nbsp;<br/> 
撑着油纸伞,独自&nbsp;<br/> 
彷徨在悠长、悠长&nbsp;<br/> 
又寂寥的雨巷,&nbsp;<br/> 
我希望逢着&nbsp;<br/> 
一个丁香一样地&nbsp;<br/> 
结着愁怨的姑娘。&nbsp;<br/> 
她是有&nbsp;<br/> 
丁香一样的颜色,&nbsp;<br/> 
丁香一样的芬芳,&nbsp;<br/> 
丁香一样的忧愁,&nbsp;<br/> 
在雨中哀怨,&nbsp;<br/> 
哀怨又彷徨;&nbsp;<br/> 
她彷徨在这寂寥的雨巷,&nbsp;<br/> 
撑着油纸伞&nbsp;<br/> 
像我一样,&nbsp;<br/> 
像我一样地&nbsp;<br/> 
默默踟躇着&nbsp;<br/> 
冷漠、凄清,又惆怅。&nbsp;<br/> 
她默默地走近,&nbsp;<br/> 
走近,又投出&nbsp;<br/> 
叹息一般的眼光&nbsp;<br/> 
她飘过&nbsp;<br/> 
像梦一般地,&nbsp;<br/> 
像梦一般地凄婉迷茫。&nbsp;<br/> 
像梦中飘过&nbsp;<br/> 
一枝丁香地,&nbsp;<br/> 
我身旁飘过这个女郎;&nbsp;<br/> 
她默默地远了,远了,&nbsp;<br/> 
到了颓圮的篱墙,&nbsp;<br/> 
走尽这雨巷。&nbsp;<br/> 
在雨的哀曲里,&nbsp;<br/> 
消了她的颜色,&nbsp;<br/> 
散了她的芬芳,&nbsp;<br/> 
消散了,甚至她的&nbsp;<br/> 
叹息般的眼光&nbsp;<br/> 
丁香般的惆怅。&nbsp;<br/> 
撑着油纸伞,独自&nbsp;<br/> 
彷徨在悠长、悠长&nbsp;<br/> 
又寂寥的雨巷,&nbsp;<br/> 
我希望飘过&nbsp;<br/> 
一个丁香一样地&nbsp;<br/> 
结着愁怨的姑娘。</div></cite></div> 
</body> 
</html> 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 您好,关于您的问题,可以通过使用CSS样式来实现关键字高亮,并且可以使用JavaScript生成随机颜色。具体实现方法可以参考以下代码: ```html <style> .highlight { background-color: #FCD5CE; /* 设置关键字高亮颜色 */ } </style> <script> function highlightKeywords() { var keywords = ["JavaScript", "CSS", "HTML"]; // 关键字列表 var elements = document.getElementsByTagName("*"); // 获取所有元素 for (var i = ; i < elements.length; i++) { var element = elements[i]; if (element.nodeType === 3) { // 判断是否为文本节点 var text = element.nodeValue; var replacedText = text; for (var j = ; j < keywords.length; j++) { var keyword = keywords[j]; var regex = new RegExp(keyword, "gi"); // 创建正则表达式,忽略大小写 if (regex.test(text)) { var span = document.createElement("span"); span.className = "highlight"; span.style.backgroundColor = getRandomColor(); // 设置随机颜色 span.textContent = keyword; replacedText = replacedText.replace(regex, span.outerHTML); } } if (replacedText !== text) { var newNode = document.createElement("span"); newNode.innerHTML = replacedText; element.parentNode.replaceChild(newNode, element); } } } } function getRandomColor() { var letters = "0123456789ABCDEF"; var color = "#"; for (var i = ; i < 6; i++) { color += letters[Math.floor(Math.random() * 16)]; } return color; } window.onload = highlightKeywords; // 页面加载完成后执行高亮函数 </script> ``` 以上代码可以实现在页面中将指定的关键字高亮,并且每个关键字高亮颜色都是随机生成的。希望对您有所帮助。 ### 回答2: 在JavaScript中,我们可以运用CSS样式和DOM操作来实现关键字高亮显示,并随机分配不同的颜色。 首先,我们需要为要高亮显示的关键字添加一个class或者id。例如,我们可以将关键字用`span`标签包裹,并设置一个class名为"highlight",如下所示: ```html <p>这是一个<span class="highlight">关键字</span>的例子。</p> ``` 接下来,在JavaScript中,我们可以通过获取所有包含关键字的元素,并为它们随机分配不同的颜色样式。 ```javascript // 获取所有拥有highlight类名的元素 const highlightElements = document.getElementsByClassName('highlight'); // 生成随机颜色的函数 function getRandomColor() { const letters = '0123456789ABCDEF'; let color = '#'; for (let i = 0; i < 6; i++) { color += letters[Math.floor(Math.random() * 16)]; } return color; } // 为每个关键字元素添加随机颜色样式 for (let element of highlightElements) { const randomColor = getRandomColor(); element.style.backgroundColor = randomColor; element.style.color = 'white'; // 可选,为了确保文本可读性 } ``` 以上代码会为所有拥有highlight类名的元素随机分配不同的背景颜色。`getRandomColor`函数会生成一个随机的十六进制颜色码,然后在循环中为每个关键字元素设置`backgroundColor`样式为生成的颜色,可以添加`color`样式属性,以确保文本的可读性。 使用这种方式,关键字在页面中将以不同的随机颜色高亮显示。 ### 回答3: 要实现JavaScript关键字的随机不同颜色高亮,可以按照以下步骤进行: 1. 首先,创建一个包含所有关键字的数组。可以使用JavaScript中的关键字列表或自定义关键字列表。 2. 使用JavaScript的Math.random()函数生成一个0到1之间的随机数。 3. 将随机数乘以关键字颜色总数并向下取整,得到一个索引值。 4. 使用该索引值从颜色数组中获取对应的颜色。 5. 将获取到的颜色应用到关键字高亮样式中,例如使用CSS的color属性。 6. 重复步骤2至5,为每个关键字生成不同的随机颜色并应用到对应的高亮样式中。 以下是示例代码实现上述步骤: ```html <!DOCTYPE html> <html> <head> <style> .highlight { color: black; font-weight: bold; } </style> </head> <body> <p id="code"> var x = 5; for (var i = 0; i < 10; i++) { console.log(i); } var y = 10; </p> <script> // 关键字列表 var keywords = [ "var", "for", "console", "log", ]; // 颜色列表 var colors = ["red", "blue", "green", "yellow", "orange"]; var codeElement = document.getElementById("code"); // 遍历关键字列表 for (var i = 0; i < keywords.length; i++) { // 生成随机颜色索引 var randomIndex = Math.floor(Math.random() * colors.length); // 获取随机颜色 var randomColor = colors[randomIndex]; // 创建高亮样式 var highlightStyle = "color: " + randomColor; // 高亮关键字 var keywordRegExp = new RegExp("\\b" + keywords[i] + "\\b", "g"); codeElement.innerHTML = codeElement.innerHTML.replace( keywordRegExp, '<span class="highlight" style="' + highlightStyle + '">$&</span>' ); } </script> </body> </html> ``` 上述代码通过使用正则表达式将关键字找出并包裹在`<span>`标签中,该标签具有带有随机颜色类的高亮样式。每次运行代码,关键字都会被高亮为不同的随机颜色。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值