基於正規表示式實現UL下LI的樣式替換功能

給我任何的發表於2022-03-14

本文例項講述了基於正規表示式實現UL下LI的樣式替換功能。分享給大家供大家參考,具體如下:

最先我想到是在UL下填充好在替換髮覺結果差強人意,沒有真正改變樣式:

$("#UlContent li").each(function (index) {
  // alert(index + ': ' + $(this).text());
  var text = $(this).text();
  var regExp = new RegExp($("#search_content").val(), 'g');
  var newText = text.replace(regExp,"<span style=\"background-color:red;\">" + $("#search_content").val() + "</span>");//將找到的關鍵字替換,加上highlight屬性;
  $(this).text(newText);//更新文章;
});

其實應該在填充進UL前進行替換:

$("#search_content").keyup(function () {
  if(CheckChinese($("#search_content").val()))
  {
   $.ajax({
    type: "POST",
    anync: true,
    url: "HelpCenterSuggestion.ashx",
    cache: false,
    dataType: "text",
    data: { m: $("#search_content").val() },
    success: function (result) {
     $("#UlContent li").remove();
      var regExp = new RegExp($("#search_content").val(), 'g');
      var newText = result.replace(regExp,"<span style=\"background-color:red;\">" + $("#search_content").val() + "</span>");//將找到的關鍵字替換,加上highlight屬性;
      $("#UlContent").append(newText);
    }
   });

PS:這裡再為大家提供2款非常方便的正規表示式工具供大家參考使用:

JavaScript正規表示式線上測試工具:

正規表示式線上生成工具:

希望本文所述對大家正規表示式學習有所幫助。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70015106/viewspace-2870895/,如需轉載,請註明出處,否則將追究法律責任。

相關文章