好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > HTML高亮關(guān)鍵字的完美解決方案

HTML高亮關(guān)鍵字的完美解決方案

熱門標(biāo)簽:周口導(dǎo)航地圖標(biāo)注 400電話辦理尚景 東莞人工外呼系統(tǒng)多少錢 商丘電話自動外呼系統(tǒng)怎么收費(fèi) 朝陽自動外呼系統(tǒng) 400電話是在哪里申請 昌邑外呼系統(tǒng) 地圖標(biāo)注地點(diǎn)下載 默納克系統(tǒng)外呼顯示inns

最近做項(xiàng)目遇到這樣的一個功能:在網(wǎng)頁中高亮關(guān)鍵字。

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

常用做法:正則替換

思路:要想高亮元素,那么需要將關(guān)鍵字提取出來用標(biāo)簽包裹,然后對標(biāo)簽進(jìn)行樣式調(diào)整。使用 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>

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

正則優(yōu)化一:僅處理位于標(biāo)簽內(nèi)的元素

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

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

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

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

正則優(yōu)化二:清除可能影響的標(biāo)簽

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

最重要的,當(dāng)標(biāo)簽值中包含 <> 符號時,此方法也不能正確的提取標(biāo)簽

總之在經(jīng)過了N多嘗試之后,通過正則都沒能有效的處理各種情況。然后換了個思路,不通過字符串的方式,通過節(jié)點(diǎn)處理。element.childNodes 可以最有效的清理標(biāo)簽內(nèi)的干擾信息。

[完美解決方案]通過 DOM 節(jié)點(diǎn)處理

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

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

但是 keyword 1 是屬于文本節(jié)點(diǎn),只能修改文本內(nèi)容,無法增加 HTML,更無法單獨(dú)控制其樣式。而文本節(jié)點(diǎn)也不能轉(zhuǎn)換為普通節(jié)點(diǎn),這也是最苦惱的事情。

最后~,本文的重點(diǎn)來了,因?yàn)檫@個功能,讓我第一次認(rèn)真接觸到了文本節(jié)點(diǎn)這個東西。從這里發(fā)現(xiàn)了Text,使用切割文本節(jié)點(diǎn)并替換的方式實(shí)現(xiàn)高亮。

源碼以及還原高亮見源碼

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

總結(jié)

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML高亮關(guān)鍵字的完美解決方案》,本文關(guān)鍵詞  HTML,高亮,關(guān)鍵字,的,完美,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML高亮關(guān)鍵字的完美解決方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML高亮關(guān)鍵字的完美解決方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: wwwwxxxx欧美| 国内精品久久久久久野外| 好男人视频社区精品免费 | 久久www成人看片| 丰满爆乳BBWBBWBBW动态| 欧美夫妇互换XXOO| 午夜精品99一区二区三区| 91视频试看| 中国xxxxxxxxx孕交| 公翁高H细节吃奶肉爽文| 69堂国产成人精品视频| 一卡二卡四卡免一卡视频| 韩国xxxx69| 辣文肉肉| 6~12呦孩精品XXXX视频视频| 91精品国产综合成人| 又黄又刺激小说推文| 国产成人精品无码免费看点牛影视 | 精品欧美一区二区三区成人片在线| 韩国大尺度R级做爰电影哪一年| gogo国模人体啪啪大尺度| 国产性夜夜春夜夜爽1A片| 国产精品国三级国产AV三线观看视频| freevoicexxx喷水| 亚洲精品国产精品国自产A片同性| 丝袜 国产 日韩 另类 制服| 成熟丰满中国女人少妇| 被啪的最爽的一次自述| 国产欧美一区二区三区在线看蜜臀| 香蕉高清免费永久在线视频| 求欧美精品网址| 人人妻人人澡人人爽人人sex免费| 国产中文久久精品| 电影风流艳妇无删减版| 国产一区二区在线观看视频| 色情成人小说软件| 罕见pans小青大尺度视频| 91av免费| 婷婷爱爱| 小女人的味道| 饥渴的老教授 (H)小说|