91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

html高亮顯示關鍵字的方法

發布時間:2020-04-09 09:59:33 來源:億速云 閱讀:504 作者:小新 欄目:web開發

本篇文章和大家了解一下html高亮顯示關鍵字的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

html高亮顯示關鍵字的方法

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

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,更無法單獨控制其樣式。而文本節點也不能轉換為普通節點。

以上就是html高亮顯示關鍵字方法的簡略介紹,當然詳細使用上面的不同還得要大家自己使用過才領會。如果想了解更多,歡迎關注億速云行業資訊頻道哦!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

农安县| 昌邑市| 习水县| 定南县| 长丰县| 罗山县| 长海县| 辽中县| 晋宁县| 淮安市| 南木林县| 游戏| 江西省| 晋宁县| 隆尧县| 九龙县| 丰原市| 衡东县| 泰宁县| 抚远县| 和田县| 上高县| 福海县| 潍坊市| 诸暨市| 莱州市| 宝应县| 海伦市| SHOW| 娱乐| 龙陵县| 通江县| 肥东县| 九台市| 松潘县| 洪湖市| 凉城县| 武安市| 越西县| 昌图县| 正阳县|