国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - 正則表達式 - 如何實現正則表達式的JavaScript的代碼高亮

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

2020-08-12 15:07正則之家 正則表達式

這篇文章主要介紹了如何實現正則表達式的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={
    "&amp;":/&/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還是其它什么語言,代碼高亮都可以直接正則匹配出來。

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25 Weibo Article 26 Weibo Article 27 Weibo Article 28 Weibo Article 29 Weibo Article 30 Weibo Article 31 Weibo Article 32 Weibo Article 33 Weibo Article 34 Weibo Article 35 Weibo Article 36 Weibo Article 37 Weibo Article 38 Weibo Article 39 Weibo Article 40
主站蜘蛛池模板: 欧美成人久久 | 成人欧美一区二区三区色青冈 | 人人人人人你人人人人人 | 日韩精品一区二区三区在线播放 | 色综合888 | 成人高清网站 | 天天综合视频网 | 欧美成人高清视频 | 亚洲一区中文字幕在线观看 | 亚洲www啪成人一区二区 | 成人综合色区 | 日本黄色网址大全 | 欧美中文字幕在线 | 欧美一区二区三区久久 | 欧美日一区 | 中文字幕在线视频观看 | 亚洲欧洲av在线 | 在线国产视频 | 仙人掌旅馆在线观看 | 亚洲综合色网 | 国产精品日本欧美一区二区三区 | 精品国产一区二区在线 | 亚洲高清视频在线 | 成人网av| 一级片在线播放 | 欧美精品欧美极品欧美激情 | 午夜久久久久久久久久一区二区 | 成人福利在线 | 国产精品亚洲一区二区三区在线 | 精品久久久久久久久久久久 | 91av国产视频 | 欧美黄色电影在线 | 国产精品久久久久久久久久久久久 | 亚洲国产精品久久久 | 深夜在线视频 | 亚洲精品影院 | 久久久亚洲国产美女国产盗摄 | 日韩欧美~中文字幕 | 欧美午夜寂寞影院 | 天天色视频 | 国产成人精品免费 |