亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Regex > 正文

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

2020-03-16 21:06:44
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了如何實現正則表達式的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 

 

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

 

復制代碼代碼如下:

(////.*|///*[/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,""":/"/g,"'":/'/g,
    "<":/</g,">":/>/g,"<br/>"://n/g,
    " ":/ /g,"  "://t/g
  })e=e.replace(s[i],i);
  return e;
};
</script>

 

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品日韩一区| 久久久久久久久中文字幕| 影音先锋日韩有码| 亚洲人成网7777777国产| 欧美精品18videosex性欧美| 欧美午夜精品久久久久久浪潮| 久久躁日日躁aaaaxxxx| 亚洲欧美激情视频| 国产日韩av高清| 中文字幕日韩欧美精品在线观看| 亚洲国产成人久久综合一区| 最近2019中文免费高清视频观看www99| 久久色免费在线视频| 亚洲欧洲在线免费| 国产z一区二区三区| 欧美日韩在线一区| 精品国产福利在线| 欧美性xxxxx| 国产精品久久久久久久久久三级| 亚洲精品国产免费| 九九九热精品免费视频观看网站| 97国产精品视频人人做人人爱| 国产精品永久免费视频| 国产成人一区二区三区| 国产精品久久久久久久7电影| 精品二区三区线观看| 欧美一区二区三区精品电影| 国产69久久精品成人看| 国产精品免费一区二区三区都可以| 久久精品影视伊人网| 精品欧美国产一区二区三区| 日韩有码在线视频| 久久精品青青大伊人av| 久久久久久久999精品视频| 亚洲精品国产精品国自产观看浪潮| 日韩在线欧美在线国产在线| 狠狠久久亚洲欧美专区| 少妇av一区二区三区| 国产精品久久久久久久app| 成人有码在线视频| 成人a在线视频| 一区二区三区高清国产| 狠狠躁天天躁日日躁欧美| 国产最新精品视频| 亚洲欧美另类国产| 国产日韩欧美电影在线观看| 91性高湖久久久久久久久_久久99| 欧美日韩一区二区在线| 全色精品综合影院| 欧美性猛交xxxxx水多| 亚洲国产精品网站| 久久亚洲精品毛片| 555www成人网| 在线色欧美三级视频| 在线看片第一页欧美| 日本一区二区三区在线播放| 欧美日韩在线观看视频| 国产精品久久久久影院日本| 亚洲自拍中文字幕| 久久久人成影片一区二区三区| 激情懂色av一区av二区av| 亚洲午夜未满十八勿入免费观看全集| 日韩禁在线播放| 欧美天天综合色影久久精品| 久久精彩免费视频| 欧美性猛交xxxx富婆弯腰| 欧美极品少妇xxxxⅹ喷水| 国产午夜精品视频| 庆余年2免费日韩剧观看大牛| 精品久久久免费| 日韩av电影国产| 亚洲第一级黄色片| 欧美最顶级的aⅴ艳星| 国产精品免费久久久久久| 亚洲一区美女视频在线观看免费| 亚洲欧美日韩国产中文专区| 全亚洲最色的网站在线观看| 欧洲永久精品大片ww免费漫画| 亚洲精品自拍偷拍| 国产女人18毛片水18精品| 日韩大陆毛片av| 亚洲国产精品久久久久| 亚洲国产精品成人va在线观看| 欧美日本黄视频| 亚洲色图偷窥自拍| 国产97在线播放| 日本免费一区二区三区视频观看| 成人免费大片黄在线播放| 久久精品中文字幕| 538国产精品一区二区免费视频| 精品成人69xx.xyz| 欧美日韩国产综合视频在线观看中文| 中文字幕日韩专区| 久久久久久久久久久成人| 欧美日韩激情美女| 日本午夜在线亚洲.国产| 亚洲全黄一级网站| 欧美一区深夜视频| 456亚洲影院| 日韩av在线网站| 欧美性猛交99久久久久99按摩| 国产在线精品成人一区二区三区| 日韩激情视频在线| 欧美午夜精品久久久久久人妖| 国产一区二区三区精品久久久| 欧美日韩国产在线看| 色爱av美腿丝袜综合粉嫩av| 亚洲一区二区三区视频| 日韩中文理论片| 一本色道久久88精品综合| 日韩av高清不卡| 久久久久久一区二区三区| 国产综合色香蕉精品| 伊人久久综合97精品| 国语自产精品视频在线看一大j8| 国产最新精品视频| 韩国福利视频一区| 国产精品精品久久久| 日韩av最新在线| 国产日韩欧美在线播放| 日韩激情第一页| 91在线视频九色| 97人人模人人爽人人喊中文字| 懂色av一区二区三区| 中文欧美在线视频| 日韩专区在线观看| 97成人在线视频| 国产91网红主播在线观看| 国产视频久久久久| 色av中文字幕一区| 51久久精品夜色国产麻豆| 亚洲乱码av中文一区二区| 亚洲午夜色婷婷在线| 国产乱肥老妇国产一区二| 日韩电影免费观看中文字幕| 日韩av不卡在线| 国产精品久久久久久久久免费看| 性欧美xxxx交| 欧美一区二区三区免费视| 91免费看片网站| 日韩免费在线看| 亚洲欧美精品一区| 日韩电影大片中文字幕| 在线成人激情视频| 久久成人综合视频| 日韩女优人人人人射在线视频| 欧美寡妇偷汉性猛交| 国产日韩专区在线| 欧美—级高清免费播放| 久久久久北条麻妃免费看| 亚洲精品自拍偷拍| 国产亚洲精品久久久久久牛牛| 欧美专区在线观看| 国产精品偷伦视频免费观看国产| 欧美亚洲国产成人精品| 国产激情久久久久| 欧美中文字幕在线视频| 九九热r在线视频精品| 一区二区三区日韩在线| 日韩av电影院| 一区二区三区视频在线| 国产91色在线|免| 91热精品视频| 国产一区二区三区在线免费观看|