婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > HTML高亮關鍵字的完美解決方案

HTML高亮關鍵字的完美解決方案

熱門標簽:周口導航地圖標注 400電話辦理尚景 東莞人工外呼系統多少錢 商丘電話自動外呼系統怎么收費 朝陽自動外呼系統 400電話是在哪里申請 昌邑外呼系統 地圖標注地點下載 默納克系統外呼顯示inns

最近做項目遇到這樣的一個功能:在網頁中高亮關鍵字。

本以為一個 innerHTML replace 就能實現的簡單操作,卻遇到了許多的問題。本文就記錄這些問題和最終的完美解決辦法, 希望能對有同樣遭遇的小伙伴有所幫助。只對結果感興趣的,忽略過程,直接跳過看結果吧~

常用做法:正則替換

思路:要想高亮元素,那么需要將關鍵字提取出來用標簽包裹,然后對標簽進行樣式調整。使用 innerHTML,或 outHTML, 而不能使用 innerText,outText。

const regex = new RegExp(keyword,"g")
element.innerHTML = element.innerHTML.replace(regex,"<b class="a">"+keyword+"</b>")
element.classList.add("highlight")

這樣做存在的隱患有如下:

()\

div
<div id="parent">
    <div class="test">test</div>
  </div>

關鍵字父節點 element 通過 class 來進行背景染色處理,對原始DOM有一定程度污染,可能對 element 再次定位造成影響。(作為插件希望盡可能少改變原始DOM)
 

正則優化一:僅處理位于標簽內的元素

var formatKeyword = text.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&') // 轉義處理keyword包含的特殊字符,如 /.
var finder = new RegExp(">.*?"++".*?<") // 提取位于標簽內的文本,避免誤操作 class、id 等

element.innerHTML = element.innerHTML.replace(finder,function(matched){
        return matched.replace(text,"<br>"+text+</br>)
})// 對提取的標簽內文本進行關鍵字替換

以能解決大多數問題,但依舊存在的問題是,只要標簽屬性存在類似 < 符號,將會打破匹配規則導致正則提取內容錯誤, HTML5 dataset 可以自定義任意內容,故這些特殊字符是無法避免的。

<div dataset="p>d">替換</div>

正則優化二:清除可能影響的標簽

<div id="keyword">keyword</div>
  =》將閉合標簽用變量替換
  [replaced1]keyword[replaced2]//閉合標簽內 id="keyword" 不會被處理
  =》
  [replaced1]<b>keyword</b>[replaced2]
  =》將暫存變量 replaced 替換為原先標簽
  <div id="keyword"><b>keyword</b></div>
  • 這種思路及源碼從這里來, 但存在問題是:
  • 如果 [replaced1] 包含 keyword, 那么替換時將發生異常

最重要的,當標簽值中包含 <> 符號時,此方法也不能正確的提取標簽

總之在經過了N多嘗試之后,通過正則都沒能有效的處理各種情況。然后換了個思路,不通過字符串的方式,通過節點處理。element.childNodes 可以最有效的清理標簽內的干擾信息。

[完美解決方案]通過 DOM 節點處理

<div id="parent">
    keyword 1
  <span id="child">
    keyword 2
  </span>
 </div>

通過 parent.childNodes 得到所有子節點。child 節點可以通過 innerText.replce(keyword,result) 的方式替換得到想要的高亮效果,如下: <span id="child"><b>keyword</b> 2</span> (遞歸處理:當child節點不含子節點時進行replace操作)。

但是 keyword 1 是屬于文本節點,只能修改文本內容,無法增加 HTML,更無法單獨控制其樣式。而文本節點也不能轉換為普通節點,這也是最苦惱的事情。

最后~,本文的重點來了,因為這個功能,讓我第一次認真接觸到了文本節點這個東西。從這里發現了Text,使用切割文本節點并替換的方式實現高亮。

源碼以及還原高亮見源碼

const reg = new RegExp(keyword.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&'))
highlight = function (node,reg){
    if (node.nodeType == 3) {  //只處理文本節點
        const match = node.data.match(new RegExp(reg));
        if (match) {
          const highlightEl = document.createElement("b");
          highlightEl.dataset.highlight="y"
          const wordNode = node.splitText(match.index)
          wordNode.splitText(match[0].length); // 切割成前 關鍵詞 后三個Text 節點
          const wordNew = document.createTextNode(wordNode.data);
          highlightEl.appendChild(wordNew);//highlight 節點構建成功
          wordNode.parentNode.replaceChild(highlightEl, wordNode);// 替換該文本節點
        }
    } else if (node.nodeType == 1 && node.dataset.highlight!="y"
    ) {
        for (var i = 0; i < node.childNodes.length; i++) {
            highlight(node.childNodes[i], reg);
            i++
        }
    }  
}

總結

以上所述是小編給大家介紹的HTML高亮關鍵字的完美解決方案,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

標簽:那曲 揭陽 阿拉善盟 湖南 福建 健身房 銅陵 沈陽

巨人網絡通訊聲明:本文標題《HTML高亮關鍵字的完美解決方案》,本文關鍵詞  HTML,高亮,關鍵字,的,完美,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《HTML高亮關鍵字的完美解決方案》相關的同類信息!
  • 本頁收集關于HTML高亮關鍵字的完美解決方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产成人午夜高潮毛片| 国产无一区二区| 日韩欧美一级二级三级久久久| 国产精品日韩成人| 激情综合五月婷婷| 欧美伦理电影网| 亚洲欧美一区二区不卡| 国产经典欧美精品| 精品88久久久久88久久久| 日本系列欧美系列| 欧美日韩国产免费一区二区| 亚洲精品第1页| 97精品国产97久久久久久久久久久久| xfplay精品久久| 国产精品久久久久桃色tv| 一区二区三区在线观看视频| 激情文学综合插| 亚洲精品在线观看视频| 久久精品国产亚洲aⅴ | 欧美在线999| 亚洲三级电影全部在线观看高清| 成人av网站免费观看| 国产日产欧产精品推荐色| 国产综合色精品一区二区三区| 欧美人伦禁忌dvd放荡欲情| 日韩激情一区二区| 在线视频国内自拍亚洲视频| 一区二区欧美国产| 欧洲精品中文字幕| 亚洲sss视频在线视频| 欧美日韩精品一区视频| 日本不卡一区二区三区| 精品久久久久久综合日本欧美| 蜜臀99久久精品久久久久久软件| 欧美一区二区大片| 国产乱码精品一品二品| 国产精品萝li| 91丨porny丨国产入口| 亚洲一区二区在线视频| 日韩色视频在线观看| 国产乱对白刺激视频不卡| 国产精品天美传媒| 日本高清不卡在线观看| 蜜臀av亚洲一区中文字幕| 久久免费看少妇高潮| 天堂蜜桃一区二区三区 | 国产最新精品精品你懂的| 久久女同精品一区二区| 成人免费的视频| 亚洲精品日韩专区silk| 制服丝袜中文字幕亚洲| 狂野欧美性猛交blacked| 国产日韩欧美不卡在线| 91黄色在线观看| 美女www一区二区| 日韩毛片在线免费观看| 欧美伊人久久久久久久久影院| 日韩激情视频网站| 中文字幕中文字幕一区| 日韩一级免费观看| 色综合久久久久综合体桃花网| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品久久久久影院老司| 国产精品小仙女| 香港成人在线视频| 国产精品美女久久久久久久| 欧美一区二区三区播放老司机| av在线不卡电影| 久久精品国产**网站演员| 亚洲精选视频免费看| 免费高清在线视频一区·| 1区2区3区国产精品| 日韩欧美成人午夜| 欧美中文字幕一区二区三区| 精品一区二区免费| 国产精品美女视频| 日韩欧美视频在线| 91看片淫黄大片一级在线观看| 狠狠色狠狠色综合系列| 性久久久久久久| 亚洲综合免费观看高清完整版在线| 国产欧美一区二区三区鸳鸯浴| 91精品国产黑色紧身裤美女| 在线免费亚洲电影| 成人激情综合网站| 国产精品99久| 久久99国产精品麻豆| 日韩在线卡一卡二| 一区二区三区免费观看| 国产精品久久免费看| 国产亚洲综合av| 久久综合色婷婷| 精品人在线二区三区| 7777女厕盗摄久久久| 亚洲一区二区三区四区五区中文| 国产精品欧美久久久久一区二区| 欧美乱熟臀69xxxxxx| 91色乱码一区二区三区| 国产精品亚洲一区二区三区在线 | 国产精品免费看片| 国产亚洲午夜高清国产拍精品| 欧美一区二区在线视频| 国产裸体歌舞团一区二区| 久久精品噜噜噜成人88aⅴ| 日韩精品一级二级| 婷婷国产在线综合| 三级亚洲高清视频| 日日夜夜一区二区| 国产日韩欧美制服另类| 欧美精品一区二区三区蜜桃| 欧美videos大乳护士334| 欧美一区二区日韩| 日韩美女视频一区二区在线观看| 欧美一区日本一区韩国一区| 欧美一二三四区在线| 精品入口麻豆88视频| 91麻豆精品国产自产在线观看一区| 欧美日韩一区三区四区| 在线播放国产精品二区一二区四区| 91国产成人在线| 欧美疯狂做受xxxx富婆| 91精品国产色综合久久久蜜香臀| 欧美美女视频在线观看| 欧美精品一区二区三| 久久―日本道色综合久久| 国产欧美日本一区视频| 国产精品久久久久四虎| 亚洲久草在线视频| 日本在线观看不卡视频| 国产乱码字幕精品高清av| 国产伦精品一区二区三区视频青涩| 另类成人小视频在线| 国产伦理精品不卡| av成人动漫在线观看| 91在线精品秘密一区二区| 欧美日韩免费在线视频| 日韩一级大片在线观看| 国产亚洲一区二区三区四区| 国产欧美日韩视频一区二区 | 日韩精品一区二区三区四区视频| 国产亚洲女人久久久久毛片| 中文字幕一区二区视频| 午夜精品成人在线| 国产一区二区美女诱惑| 在线欧美小视频| 欧美va在线播放| 综合激情成人伊人| 蜜臀av性久久久久蜜臀aⅴ| 成人视屏免费看| 日韩一区二区视频在线观看| 中文字幕在线不卡一区二区三区| 日韩国产欧美一区二区三区| 99久久夜色精品国产网站| 日韩一区二区免费在线电影| 国产精品视频在线看| 奇米综合一区二区三区精品视频| www.成人在线| 精品国产免费人成电影在线观看四季 | 亚洲综合色自拍一区| 精品综合久久久久久8888| 99re热视频精品| 精品久久久久久久人人人人传媒| 欧美国产一区二区在线观看| 亚洲午夜久久久久久久久电影网| 精品一区二区三区蜜桃| 91欧美一区二区| 久久嫩草精品久久久精品一| 亚洲超碰97人人做人人爱| 成人黄色在线看| 欧美人成免费网站| 亚洲日本一区二区| 国产成人在线网站| 欧美日韩国产成人在线91| 国产精品视频在线看| 美女免费视频一区二区| 色乱码一区二区三区88| 精品国产免费人成电影在线观看四季| 亚洲大片一区二区三区| 91免费视频网| 日本一区二区三区电影| 激情六月婷婷久久| 日韩一区二区视频在线观看| 日韩成人精品视频| 欧美日韩免费高清一区色橹橹| 国产精品美女久久久久久2018 | 国产精品成人一区二区艾草| 狠狠色狠狠色综合日日91app| 91国产成人在线| 1000精品久久久久久久久| 狠狠色丁香婷婷综合久久片| 欧美一二三区在线| 亚洲成人精品一区二区| 欧美三级一区二区| 亚洲国产精品影院| 91国内精品野花午夜精品| 国产日韩欧美一区二区三区综合 | 一区二区高清视频在线观看| 成人18视频日本| 综合分类小说区另类春色亚洲小说欧美 | 精品伊人久久久久7777人|