国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery實現高亮顯示網頁關鍵詞的方法

2019-11-20 11:53:20
字體:
來源:轉載
供稿:網友

本文實例講述了jQuery實現高亮顯示網頁關鍵詞的方法。分享給大家供大家參考。具體如下:

這是一款基于jquery實現的高亮顯示網頁上搜索關鍵詞的代碼,當你在文本框中輸入的時候,如果下面的正文中包括你輸入的內容,也就是關鍵字,那么這些關鍵字是會高亮顯示的,被動態添加成黃色,看上去很醒目,就像百度快照顯示關鍵詞的樣子。

運行效果如下圖所示:

具體代碼如下:

<!DOCTYPE html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>jquery文字高亮顯示</title><style type="text/css">.highlight {  background-color: #fff34d;  -moz-border-radius: 5px; /* FF1+ */  -webkit-border-radius: 5px; /* Saf3-4 */  border-radius: 5px; /* Opera 10.5, IE 9, Saf5, Chrome */  -moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.7); /* FF3.5+ */  -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.7); /* Saf3.0+, Chrome */  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.7); /* Opera 10.5+, IE 9.0 */}.highlight {  padding:1px 4px;  margin:0 -4px;}</style></head><body>Search: <input type="text" id="text-search" /><p>This can include web design, web content development, client liaison, client-side/server-side scripting, web server and network security configuration, and e-commerce development. However, among web professionals, "web development" usually refers to the main non-design aspects of building web sites: writing markup and coding. Web development can range from developing the simplest static single page of plain text to the most complex web-based internet applications, electronic businesses, or social ntwork services.</p>(Text from Wikipedia)<script type="text/javascript" src="jquery-1.6.2.min.js"></script><script type="text/javascript">jQuery.fn.highlight = function(pat) { function innerHighlight(node, pat) { var skip = 0; if (node.nodeType == 3) {  var pos = node.data.toUpperCase().indexOf(pat);  if (pos >= 0) {  var spannode = document.createElement('span');  spannode.className = 'highlight';  var middlebit = node.splitText(pos);  var endbit = middlebit.splitText(pat.length);  var middleclone = middlebit.cloneNode(true);  spannode.appendChild(middleclone);  middlebit.parentNode.replaceChild(spannode, middlebit);  skip = 1;  } } else if (node.nodeType == 1 && node.childNodes && !/(script|style)/i.test(node.tagName)) {  for (var i = 0; i < node.childNodes.length; ++i) {  i += innerHighlight(node.childNodes[i], pat);  } } return skip; } return this.each(function() { innerHighlight(this, pat.toUpperCase()); });};jQuery.fn.removeHighlight = function() { function newNormalize(node) {  for (var i = 0, children = node.childNodes, nodeCount = children.length; i < nodeCount; i++) {    var child = children[i];    if (child.nodeType == 1) {      newNormalize(child);      continue;    }    if (child.nodeType != 3) { continue; }    var next = child.nextSibling;    if (next == null || next.nodeType != 3) { continue; }    var combined_text = child.nodeValue + next.nodeValue;    new_node = node.ownerDocument.createTextNode(combined_text);    node.insertBefore(new_node, child);    node.removeChild(child);    node.removeChild(next);    i--;    nodeCount--;  } }return this.find("span.highlight").each(function() {  var thisParent = this.parentNode;  thisParent.replaceChild(this.firstChild, this);  newNormalize(thisParent); }).end();};</script><script type="text/javascript">$(function() {  $('#text-search').bind('keyup change', function(ev) {    // pull in the new value    var searchTerm = $(this).val();    // remove any old highlighted terms    $('body').removeHighlight();    // disable highlighting if empty    if ( searchTerm ) {      // highlight the new term      $('body').highlight( searchTerm );    }  });});</script></body></html>

希望本文所述對大家的jquery程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 建昌县| 乡城县| 东阳市| 信宜市| 吉安县| 兴隆县| 仁化县| 伊通| 上饶县| 大姚县| 柘荣县| 子洲县| 固阳县| 象州县| 大渡口区| 宁河县| 迭部县| 天门市| 余江县| 稷山县| 江津市| 专栏| 彭山县| 阜新市| 克拉玛依市| 宽城| 平果县| 阿克苏市| 土默特左旗| 龙江县| 从江县| 榆林市| 马龙县| 嘉祥县| 上虞市| 澎湖县| 遂溪县| 绍兴市| 正镶白旗| 威远县| 卢湾区|