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

主頁 > 知識庫 > 如何實現正則表達式的JavaScript的代碼高亮

如何實現正則表達式的JavaScript的代碼高亮

熱門標簽:上海銷售電銷機器人軟件 哈爾濱公司外呼系統代理 遼寧秒客來電話機器人 地圖標注店鋪地圖標注酒店 惠安地圖標注 山東外呼系統聯系方式 浙江營銷外呼系統有哪些 淄博市張店區地圖標注 自己做的電銷機器人

今天想改一下JS的高亮的配色,憋了一下午憋出了這個這個正則表達式。
  下面這老長老長了的玩意兒是個正則表達式,看到了別嚇壞了。

復制代碼 代碼如下:

/(\/\/.*|\/\*[\S\s]+?\*\/)|((["'])(?:\\.|[^\\\n])*?\3)|\b(break|continue|do|for|in|function|if|else|return|switch|this|throw|try|catch|finally|var|while|with|case|new|typeof|instance|delete|void)\b|\b(Object|Array|String|Number|Boolean|Function|RegExp|Date|Math|window|document|navigator|location)\b|\b(true|false)\b|\b(null|undefined|NaN)\b|(?:[^\W\d]|\$)[\$\w]*|(0[xX][0-9a-fA-F]+|\d+(?:\.\d+)?(?:[eE]\d+)?)|(?:[^\)\]\}]|^)(\/(?!\*)(?:\\.|[^\\\/\n])+?\/[gim]*)|[\S\s]/g

  現在,我們可以來慢慢分析它。仔細看這個正則表達式你會發現,它們是很多個正則表達式用|連接起來的。現在,我們把它用|分割,逐個分析。

復制代碼 代碼如下:

(\/\/.*|\/\*[\S\s]+?\*\/)

  這是第二個,這個正則表達式是用來匹配字符串的。字符串可以在單引號和雙引號中,所以我們匹配這兩個的任意一個。這里需要用一個括號把它括起來表示它是一個獲取匹配(“獲取匹配”的“獲取”是名詞),因為在結束的地方還需要匹配這個字符。在匹配字符串結束的地方可以用后向引用\3來匹配字符串開始的字符,也就是開始時的引號種類。如果你從這整個正則表達式的開頭開始數,你就會發現["']外面的括號是整個正則表達式中的第三個獲取匹配。這就是字符串的頭尾部分,中間的部分由于字符串是可以包含轉義的,所以我們一旦遇到反斜杠就直接跳過它后面那個字符,因為反斜杠后面包含的是轉義。但是這僅僅是匹配轉義,所以我們要用或運算|連接一個匹配非轉義的表達式,那就是[^\\]。可是這個是匹配非反斜杠的任何字符,它可以包含換行,而JS中的字符串是不允許寫成換行的。所以我們需要加個\n讓它不匹配換行。由于我們使用了或來連接,而或的優先級非常低,所以需要在旁邊加上括號來修正優先級。如果使用普通的括號就會占用一個獲取匹配,所以我們要使用(?:)來完成一個非獲取匹配。

復制代碼 代碼如下:

\b(break|continue|do|for|in|function|if|else|return|switch|this|throw|try|catch|finally|var|while|with|case|new|typeof|instance|delete|void)\b|\b(Object|Array|String|Number|Boolean|Function|RegExp|Date|Math|window|document|navigator|location)\b|\b(true|false)\b|\b(null|undefined|NaN)\b

  這是第3、4、5、6個,這些只是匹配一些關鍵字,由于需要的顏色不同所以被分組了。這沒什么好說的,跳過。

復制代碼 代碼如下:

(?:[^\W\d]|\$)[\$\w]*

  這是第七個,它的作用是匹配普通的變量名。如果變量名的字符不消耗掉,后面匹配數字的就有可能會把變量名中的數字匹配輸出來。所以這一步是必須的。你會發現這一步沒有任何獲取匹配,因為變量名的顏色是默認顏色,我們不獲取它。根據JS的命名規則,變量名是不能以數字開頭的,所以我們用[^\W\d]|\$匹配一個變量的開頭。后面則可以匹配數字、字母、下劃線、美元符號,任意次。這樣變量名就被消耗掉了。

復制代碼 代碼如下:

(0[xX][0-9a-fA-F]+|\d+(?:\.\d+)?(?:[eE]\d+)?)

  這是第八個,匹配數字的。由于數字的表達方式有兩種,所以我們要分開寫。|的左邊是16進制的數字寫法。右邊是普通的數字寫法,這個可以包含小數和科學計數法。由于小數和科學計數法都是可選存在的,所以我們把它括號起來,后面加上問號作為可選匹配。

復制代碼 代碼如下:

(?:[^\)\]\}]|^)(\/(?!\*)(?:\\.|[^\\\/\n])+?\/[gim]*)

  這是第九個,匹配正則表達式的。前面有個非獲取匹配,匹配非括號的結束。因為如果存在括號,那么斜桿就有可能表示的是除號而不是正則表達式了。后面就是正則表達式的匹配,和字符串的匹配類似,只不過最后多了一個[gim]*。這是正則表達式的三種匹配模式,也是屬于正則表達式的范疇,所以我們要匹配并獲取它。

復制代碼 代碼如下:

[\S\s]

  最后一個是匹配所有上面沒有匹配到的字符,我們必須匹配到每一個字符。因為它們都需要做一次HTML轉義。
  這樣,這個長長的正則就分析完了。下面是實現的例子。

復制代碼 代碼如下:

style>body {font:14px/18px Consolas;}/style>
script id="code">
//讀入當前代碼
var code=document.getElementById("code").innerHTML;
//修正換行的瀏覽器差異,去掉頭尾的換行和空格
code=code.replace(/\r\n|[\r\n]/g,"\n").replace(/^\s+|\s+$/g,"");
//開始主匹配
code=code.replace(/(\/\/.*|\/\*[.\s]+?\*\/)|((["'])(?:\\.|[^\\\n])*?\3)|\b(break|continue|do|for|in|function|if|else|return|switch|this|throw|try|catch|finally|var|while|with|case|new|typeof|instance|delete|void)\b|\b(Object|Array|String|Number|Boolean|Function|RegExp|Date|Math|window|document|navigator|location)\b|\b(true|false)\b|\b(null|undefined|NaN)\b|(?:[^\W\d]|\$)[\$\w]*|(0[xX][0-9a-fA-F]+|\d+(?:\.\d+)?(?:[eE]\d+)?)|(?:[^\)\]\}]|^)(\/(?!\*)(?:\\.|[^\\\/\n])+?\/[gim]*)|[.\s]/g,function(){
  var a,l,i,s;
  a=arguments;
  //循環匹配到的位置
  for(i=1;i=9;i++)if(s=a[i]){
    s=htmlEncode(s);
    //每個獲取匹配的位置都著上不同的顏色
    switch(i){
      case 1://注釋
      return s.fontcolor("#998877").italics();
      case 2:case 3://字符串
      return s.fontcolor("#AA5544");
      case 4://關鍵詞
      return s.fontcolor("#333388");
      case 5://內置對象
      return s.fontcolor("#5555AA");
      case 6://布爾值
      return s.fontcolor("#DD6600");
      case 7://空值
      return s.fontcolor("#BB4433");
      case 8://數字
      return s.fontcolor("#CC3322");
      case 9://正則表達式
      //這個比較特殊,匹配到的和獲取的有些不同
      //匹配的時候,前面有個非獲取匹配,所以我們要保留非獲取匹配的部分
      return htmlEncode(a[0]).replace(s,s.fontcolor("#33AA33"));
    };
  };
  //沒有獲取匹配就直接轉義輸出
  return htmlEncode(a[0]);
});

//輸出結果
document.write(code);

//HTML的轉義函數
function htmlEncode(e){
  var i,s;
  for(i in s={
    ""://g,"quot;":/"/g,"#039;":/'/g,
    "lt;"://g,"gt;":/>/g,"br/>":/\n/g,
    "nbsp;":/ /g,"nbsp;nbsp;":/\t/g
  })e=e.replace(s[i],i);
  return e;
};
/script>

  由于今天在趕這篇文章,沒時間做這個代碼的優化了。應該還有很多小漏洞,不過整體思路就是這樣。這樣無論是JS還是其它什么語言,代碼高亮都可以直接正則匹配出來。

您可能感興趣的文章:
  • PHP正則表達式基本函數 修飾符 元字符和需轉義字符說明
  • JavaScript正則表達式驗證身份證號碼是否合法(兩種方法)
  • 如何用javascript正則表達式驗證身份證號碼是否合法
  • 正則表達式提取img的src
  • javascript正則表達式參數/g與/i及/gi的使用指南
  • php使用curl和正則表達式抓取網頁數據示例
  • JS使用replace()方法和正則表達式進行字符串的搜索與替換實例
  • javascript中正則表達式反向引用示例介紹
  • JavaScript表單通過正則表達式驗證電話號碼
  • C#正則表達式轉義字符介紹

標簽:泰州 重慶 銅川 綿陽 長沙 宣城 無錫 西安

巨人網絡通訊聲明:本文標題《如何實現正則表達式的JavaScript的代碼高亮》,本文關鍵詞  如何,實現,正則,表達式,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《如何實現正則表達式的JavaScript的代碼高亮》相關的同類信息!
  • 本頁收集關于如何實現正則表達式的JavaScript的代碼高亮的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    www.爱久久.com| 久久精品国产精品青草| 国产精品色噜噜| 久久精品国产99| 欧美日韩在线亚洲一区蜜芽| 一区二区三区影院| 91免费视频网| 亚洲第一av色| 欧美一区二区精美| 日韩国产一区二| 日韩一级精品视频在线观看| 蜜桃久久久久久| 久久久国产综合精品女国产盗摄| a4yy欧美一区二区三区| 久久精品一区二区| 成人app下载| 亚洲欧洲精品一区二区三区| 色综合久久九月婷婷色综合| 一区二区三区中文字幕电影| 色综合色狠狠天天综合色| 一区二区三区四区蜜桃| 欧美日韩久久不卡| 美脚の诱脚舐め脚责91 | 天堂午夜影视日韩欧美一区二区| 欧美三级资源在线| 亚洲成人免费视频| 日韩女同互慰一区二区| 精品制服美女久久| 中文字幕在线一区| 91精品免费在线观看| 日韩精品每日更新| 久久亚洲综合色一区二区三区| 国产99久久久久| 一区二区三区中文字幕精品精品| 69堂亚洲精品首页| 从欧美一区二区三区| 国产精品人妖ts系列视频| 91无套直看片红桃| 青青青伊人色综合久久| 综合色天天鬼久久鬼色| 2024国产精品| 精品视频123区在线观看| 粉嫩在线一区二区三区视频| 亚洲亚洲人成综合网络| 欧美国产欧美亚州国产日韩mv天天看完整| 在线观看亚洲一区| 91精品国产黑色紧身裤美女| 激情久久五月天| 亚洲日本va午夜在线影院| 日韩一区二区三区三四区视频在线观看 | 波多野结衣在线一区| 美女脱光内衣内裤视频久久网站| 亚洲欧洲日韩综合一区二区| 日韩精品资源二区在线| 欧美性xxxxx极品少妇| 成人性生交大片免费看视频在线 | 成人少妇影院yyyy| 午夜一区二区三区视频| 亚洲乱码日产精品bd| 精品少妇一区二区| 欧美日免费三级在线| 99亚偷拍自图区亚洲| 国产成人午夜视频| 久久超碰97中文字幕| 日本不卡一区二区| 午夜在线成人av| 亚洲午夜一区二区| 亚洲线精品一区二区三区| 亚洲一区二区三区在线| 亚洲综合色噜噜狠狠| 亚洲欧美日韩一区二区三区在线观看| 国产亚洲一区二区三区| 欧美成人aa大片| 精品国产99国产精品| 国产精品大尺度| 中文字幕在线观看一区| 国产精品国产三级国产普通话99 | 视频一区在线播放| 天堂成人国产精品一区| 午夜av电影一区| 亚洲aaa精品| 午夜电影一区二区三区| 亚洲一区二区欧美激情| 亚洲欧美在线观看| 中文字幕一区在线观看| 亚洲免费观看高清完整版在线观看| 亚洲欧美色图小说| 亚洲一区二区中文在线| 天天综合日日夜夜精品| 奇米精品一区二区三区在线观看| 免费人成精品欧美精品| 国产曰批免费观看久久久| 国产精品538一区二区在线| 成人精品国产福利| 欧美午夜在线观看| 91精品久久久久久蜜臀| 久久久五月婷婷| 最新高清无码专区| 亚洲bt欧美bt精品777| 久久精品国产精品青草| 不卡av在线免费观看| 欧美在线一二三| 26uuu国产电影一区二区| 日韩伦理av电影| 另类欧美日韩国产在线| 不卡一区二区中文字幕| 91精品国产福利在线观看| 国产婷婷一区二区| 亚洲美腿欧美偷拍| 午夜久久久久久久久久一区二区| 国内精品自线一区二区三区视频| 国产精品综合二区| 欧美探花视频资源| 中文字幕的久久| 日韩成人一级片| 欧美不卡激情三级在线观看| 91精品福利在线一区二区三区| 欧美电视剧在线看免费| 中文字幕综合网| 久久精品免费看| 97久久久精品综合88久久| 欧美性做爰猛烈叫床潮| 成人动漫精品一区二区| 欧美主播一区二区三区| 久久伊人蜜桃av一区二区| 亚洲无人区一区| 成人国产精品免费观看视频| 91啪在线观看| 日韩一级欧美一级| 亚洲综合色区另类av| 免费在线观看不卡| 99国产精品久久久久久久久久| 亚洲精品一区二区三区精华液 | 亚洲一区二区三区激情| 成人免费看视频| 久久先锋影音av鲁色资源网| 伦理电影国产精品| 日韩一卡二卡三卡四卡| 午夜免费欧美电影| 欧美一区中文字幕| 久久国产人妖系列| 日韩欧美一区二区免费| 婷婷综合另类小说色区| 欧美综合一区二区| 亚洲精品中文在线影院| 成人免费av资源| 亚洲综合一区在线| 欧美精品一级二级三级| 一区二区三区中文在线观看| 日韩福利视频网| av成人老司机| 国产二区国产一区在线观看| 成人动漫在线一区| 91久久奴性调教| 欧美日韩国产123区| 2023国产精品| 亚洲国产精品麻豆| 国产成人精品影视| 欧美肥大bbwbbw高潮| 欧美激情一区二区三区四区| 久久国内精品自在自线400部| 日韩国产精品91| 欧洲视频一区二区| 欧美另类z0zxhd电影| 国产精品日日摸夜夜摸av| 激情综合一区二区三区| 欧美日韩一区二区三区不卡 | 99久久er热在这里只有精品15 | 中文字幕第一页久久| 亚洲国产精品传媒在线观看| 日韩美一区二区三区| 国产精品国产三级国产三级人妇| 樱花草国产18久久久久| 久久影院视频免费| 久久久综合精品| 日日夜夜精品视频免费 | 久久久国产精品麻豆| 中文欧美字幕免费| 欧美优质美女网站| 久久精品亚洲精品国产欧美| 欧美在线不卡视频| 日韩理论片一区二区| 丝袜美腿亚洲色图| 国产精品国产精品国产专区不片| 国产一区二区三区高清播放| 亚洲一二三四在线观看| 欧美少妇一区二区| 成人一级视频在线观看| 日韩精品最新网址| 亚洲天堂中文字幕| 精品国产三级电影在线观看| 五月婷婷久久丁香| 在线影院国内精品| 精品久久国产老人久久综合| 在线观看一区日韩| 亚洲.国产.中文慕字在线| 91成人在线精品| 色噜噜久久综合| 洋洋成人永久网站入口| 久久女同精品一区二区|