亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

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

如何實現(xiàn)正則表達式的JavaScript的代碼高亮

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

今天想改一下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

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

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

\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個,這些只是匹配一些關(guān)鍵字,由于需要的顏色不同所以被分組了。這沒什么好說的,跳過。

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

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

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

復制代碼 代碼如下:

[\S\s]

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

復制代碼 代碼如下:

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;
  //循環(huán)匹配到的位置
  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://關(guān)鍵詞
      return s.fontcolor("#333388");
      case 5://內(nèi)置對象
      return s.fontcolor("#5555AA");
      case 6://布爾值
      return s.fontcolor("#DD6600");
      case 7://空值
      return s.fontcolor("#BB4433");
      case 8://數(shù)字
      return s.fontcolor("#CC3322");
      case 9://正則表達式
      //這個比較特殊,匹配到的和獲取的有些不同
      //匹配的時候,前面有個非獲取匹配,所以我們要保留非獲取匹配的部分
      return htmlEncode(a[0]).replace(s,s.fontcolor("#33AA33"));
    };
  };
  //沒有獲取匹配就直接轉(zhuǎn)義輸出
  return htmlEncode(a[0]);
});

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

//HTML的轉(zhuǎn)義函數(shù)
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>

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

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標題《如何實現(xiàn)正則表達式的JavaScript的代碼高亮》,本文關(guān)鍵詞  如何,實現(xiàn),正則,表達式,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《如何實現(xiàn)正則表達式的JavaScript的代碼高亮》相關(guān)的同類信息!
  • 本頁收集關(guān)于如何實現(xiàn)正則表達式的JavaScript的代碼高亮的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日韩中文字幕一区| 日韩中文字幕一区| 欧美一级视频免费| 欧美激情影院| 国产视频一区二区在线观看| 91麻豆国产| 日本免费乱人伦在线观看| 亚洲精品久久玖玖玖玖| 午夜在线观看视频免费 成人| 日本伦理网站| 黄色福利| 亚洲 国产精品 日韩| 国产福利免费视频| 精品在线观看一区| 免费的黄视频| 国产精品免费久久| 日韩中文字幕在线播放| 夜夜操网| 黄视频网站免费| 高清一级淫片a级中文字幕| 日本在线播放一区| 久久成人性色生活片| 青青久久精品| 国产网站在线| 中文字幕一区二区三区 精品| 深夜做爰性大片中文| 精品视频一区二区三区免费| 国产精品免费久久| 在线观看成人网| 亚洲精品久久玖玖玖玖| 国产一区二区精品尤物| 99久久精品国产高清一区二区| 久久国产精品自由自在| 精品毛片视频| 国产伦精品一区二区三区无广告| 美女被草网站| 国产亚洲免费观看| 免费国产在线视频| 日韩一级黄色大片| 999久久狠狠免费精品| 九九九网站| 国产一区二区精品在线观看| 国产网站免费视频| 中文字幕一区二区三区精彩视频| 美女被草网站| 亚洲第一页色| 91麻豆精品国产自产在线| 日本免费看视频| 九九干| 夜夜操网| 亚洲 激情| 精品国产一区二区三区免费 | 久久久久久久男人的天堂| 欧美大片一区| 亚洲第一色在线| 999久久狠狠免费精品| 精品视频在线看| 九九九国产| 国产一区精品| 韩国三级视频网站| 欧美18性精品| 国产麻豆精品hdvideoss| 美女免费毛片| 久久成人综合网| 可以免费看污视频的网站| 国产视频久久久| 国产成人女人在线视频观看| 99色视频在线观看| 久久国产精品自线拍免费| 日本免费乱人伦在线观看| 深夜做爰性大片中文| 国产成人女人在线视频观看| 国产成人啪精品视频免费软件| 国产网站免费观看| 久久成人综合网| 二级特黄绝大片免费视频大片| 91麻豆国产福利精品| 91麻豆精品国产自产在线| 天天色成人网| 色综合久久天天综合观看| 欧美一级视频高清片| 成人av在线播放| 99热精品在线| 成人免费网站视频ww| 国产一区二区精品在线观看| 韩国三级香港三级日本三级la | 国产美女在线观看| 青青久久网| 欧美激情一区二区三区中文字幕| 九九热国产视频| 天天做人人爱夜夜爽2020毛片| 久久久成人影院| 韩国毛片| 日本伦理片网站| 99色视频| 99久久精品国产免费| 亚欧成人乱码一区二区| 国产成人精品影视| 欧美激情一区二区三区在线 | 99久久精品费精品国产一区二区| 九九九国产| 日韩中文字幕在线播放| 午夜欧美成人久久久久久| 亚欧成人乱码一区二区| 九九免费精品视频| 精品国产一级毛片| 欧美1区| 国产欧美精品| 99色视频| 欧美α片无限看在线观看免费| 欧美一级视频免费| 久久国产精品自线拍免费| 国产激情一区二区三区| 亚欧视频在线| 久久精品人人做人人爽97| 亚洲精品永久一区| 国产亚洲精品aaa大片| 国产伦精品一区三区视频| 亚洲 欧美 成人日韩| 九九九国产| 99久久精品国产麻豆| a级精品九九九大片免费看| 欧美激情一区二区三区在线播放 | 青草国产在线观看| 精品国产亚洲人成在线| 国产成人精品一区二区视频| 韩国三级视频网站| 精品视频在线观看免费| 麻豆网站在线看| 亚洲精品永久一区| 天天色成人网| 欧美激情一区二区三区视频 | 欧美激情在线精品video| 欧美大片毛片aaa免费看| 国产美女在线观看| 欧美日本免费| 日韩一级黄色| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 91麻豆国产福利精品| 精品国产一级毛片| 精品国产三级a| 久久久久久久久综合影视网| 毛片成人永久免费视频| 国产伦精品一区二区三区无广告 | 国产伦久视频免费观看视频| 天天做日日干| 99久久网站| 国产麻豆精品高清在线播放| 天天色成人网| 国产高清视频免费观看| 精品国产一区二区三区久| 天天做日日爱| 欧美1区| 欧美一区二区三区在线观看| 国产综合91天堂亚洲国产| 亚洲精品永久一区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 欧美18性精品| 国产极品白嫩美女在线观看看| 欧美激情一区二区三区在线播放 | 精品在线观看一区| 黄色短视频网站| 亚洲 欧美 成人日韩| 国产成+人+综合+亚洲不卡| 成人免费观看的视频黄页| 久久99中文字幕| 九九热国产视频| 国产网站免费| 国产高清视频免费观看| 麻豆污视频| 韩国三级香港三级日本三级la | 999久久狠狠免费精品| 亚洲第一页色| 日日日夜夜操| 国产不卡在线观看视频| 欧美激情一区二区三区中文字幕| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产综合91天堂亚洲国产| 一级片片| 国产一区二区精品在线观看| 日韩女人做爰大片| 国产网站在线| 麻豆系列 在线视频| 国产不卡在线观看| 高清一级做a爱过程不卡视频| 色综合久久久久综合体桃花网| 午夜欧美成人久久久久久| 韩国三级香港三级日本三级la | 美女免费精品视频在线观看| 天天做日日爱| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产麻豆精品| 国产麻豆精品免费密入口| 精品国产一区二区三区久| 国产不卡福利| 欧美一级视频免费| 久久99这里只有精品国产| 日本在线www| 美女免费毛片| 欧美18性精品|