欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2014年05月13日 16:55:21   作者:  
這篇文章主要介紹了如何實(shí)現(xiàn)正則表達(dá)式的JavaScript的代碼高亮方法,需要的朋友可以參考下

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

復(fù)制代碼 代碼如下:

/(\/\/.*|\/\*[\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)在,我們可以來(lái)慢慢分析它。仔細(xì)看這個(gè)正則表達(dá)式你會(huì)發(fā)現(xiàn),它們是很多個(gè)正則表達(dá)式用|連接起來(lái)的?,F(xiàn)在,我們把它用|分割,逐個(gè)分析。

復(fù)制代碼 代碼如下:

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

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

復(fù)制代碼 代碼如下:

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

復(fù)制代碼 代碼如下:

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

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

復(fù)制代碼 代碼如下:

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

  這是第八個(gè),匹配數(shù)字的。由于數(shù)字的表達(dá)方式有兩種,所以我們要分開(kāi)寫(xiě)。|的左邊是16進(jìn)制的數(shù)字寫(xiě)法。右邊是普通的數(shù)字寫(xiě)法,這個(gè)可以包含小數(shù)和科學(xué)計(jì)數(shù)法。由于小數(shù)和科學(xué)計(jì)數(shù)法都是可選存在的,所以我們把它括號(hào)起來(lái),后面加上問(wèn)號(hào)作為可選匹配。

復(fù)制代碼 代碼如下:

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

  這是第九個(gè),匹配正則表達(dá)式的。前面有個(gè)非獲取匹配,匹配非括號(hào)的結(jié)束。因?yàn)槿绻嬖诶ㄌ?hào),那么斜桿就有可能表示的是除號(hào)而不是正則表達(dá)式了。后面就是正則表達(dá)式的匹配,和字符串的匹配類(lèi)似,只不過(guò)最后多了一個(gè)[gim]*。這是正則表達(dá)式的三種匹配模式,也是屬于正則表達(dá)式的范疇,所以我們要匹配并獲取它。

復(fù)制代碼 代碼如下:

[\S\s]

  最后一個(gè)是匹配所有上面沒(méi)有匹配到的字符,我們必須匹配到每一個(gè)字符。因?yàn)樗鼈兌夹枰鲆淮蜨TML轉(zhuǎn)義。
  這樣,這個(gè)長(zhǎng)長(zhǎng)的正則就分析完了。下面是實(shí)現(xiàn)的例子。

復(fù)制代碼 代碼如下:

<style>body {font:14px/18px Consolas;}</style>
<script id="code">
//讀入當(dāng)前代碼
var code=document.getElementById("code").innerHTML;
//修正換行的瀏覽器差異,去掉頭尾的換行和空格
code=code.replace(/\r\n|[\r\n]/g,"\n").replace(/^\s+|\s+$/g,"");
//開(kāi)始主匹配
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);
    //每個(gè)獲取匹配的位置都著上不同的顏色
    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)置對(duì)象
      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://正則表達(dá)式
      //這個(gè)比較特殊,匹配到的和獲取的有些不同
      //匹配的時(shí)候,前面有個(gè)非獲取匹配,所以我們要保留非獲取匹配的部分
      return htmlEncode(a[0]).replace(s,s.fontcolor("#33AA33"));
    };
  };
  //沒(méi)有獲取匹配就直接轉(zhuǎn)義輸出
  return htmlEncode(a[0]);
});

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

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

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

相關(guān)文章

  • mysql正則表達(dá)式 LIKE 通配符

    mysql正則表達(dá)式 LIKE 通配符

    由MySQL提供的模式匹配的其他類(lèi)型是使用擴(kuò)展正則表達(dá)式。當(dāng)你對(duì)這類(lèi)模式進(jìn)行匹配測(cè)試時(shí),使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它們是同義詞)。
    2009-10-10
  • 正則表達(dá)式[\s\S]*與[\w\W]* 什么意思

    正則表達(dá)式[\s\S]*與[\w\W]* 什么意思

    很多人咨詢(xún)[\s\S]*與[\w\W]* 什么意思,不是有.了嗎,那么它們的組合,表示所有的都匹配,與它相對(duì)應(yīng)的,有[\w\W]等,意義完全相同,需要的朋友可以參考下
    2020-03-03
  • swift中的正則表達(dá)式小結(jié)

    swift中的正則表達(dá)式小結(jié)

    正則表達(dá)式是對(duì)字符串操作的一種邏輯公式,用事先定義好的一些特定字符、及這些特定字符的組合,組成一個(gè)"規(guī)則字符串",這個(gè)"規(guī)則字符串"用來(lái)表達(dá)對(duì)字符串的一種過(guò)濾邏輯。
    2015-10-10
  • 用正則表達(dá)式表示不包含2950的字符串

    用正則表達(dá)式表示不包含2950的字符串

    或者說(shuō)有一條命令 hostname [string],當(dāng)string是不包含2950時(shí),是true,包含2950時(shí)是false。
    2009-09-09
  • 如何使用正則表達(dá)式保留部分內(nèi)容的替換功能

    如何使用正則表達(dá)式保留部分內(nèi)容的替換功能

    其實(shí)工作中一直在用到正則表達(dá)式,只是用來(lái)替換的操作顯然沒(méi)有那么多,今天偶然遇到,還是有點(diǎn)陌生的,這里記錄一下,下面這篇文章主要給大家介紹了關(guān)于如何使用正則表達(dá)式保留部分內(nèi)容的替換功能,需要的朋友可以參考下
    2023-03-03
  • javascript正則表達(dá)式標(biāo)記中/g /i /m的用法,以及實(shí)例

    javascript正則表達(dá)式標(biāo)記中/g /i /m的用法,以及實(shí)例

    正則的思想都是一樣的,但是具體的寫(xiě)法會(huì)有所不同,在這里提到的/g,/i,/m在其他的地方也許就不能用了,需要的朋友可以參考下
    2020-02-02
  • Javascript使用正則驗(yàn)證身份證號(hào)(簡(jiǎn)單)

    Javascript使用正則驗(yàn)證身份證號(hào)(簡(jiǎn)單)

    本文以javascript為例給大家介紹了正則表達(dá)式驗(yàn)證身份證號(hào)的方法,非常不錯(cuò),介紹的非常詳細(xì),具有參考借鑒價(jià)值,感興趣的朋友一起看下吧
    2016-08-08
  • 使用正則表達(dá)式找出不包含特定字符串的條目

    使用正則表達(dá)式找出不包含特定字符串的條目

    今天在寫(xiě)一個(gè)功能的時(shí)候,需要替換不包含指定字符串的正則,看到了一篇好文章特整理分享下,方便需要的朋友
    2014-09-09
  • 淺談?wù)齽t速記法的技巧

    淺談?wù)齽t速記法的技巧

    這篇文章主要介紹了淺談?wù)齽t速記法的技巧,對(duì)大部分人來(lái)說(shuō),正則主要是難記,其實(shí)只要對(duì)正則符號(hào)分類(lèi)記憶,就會(huì)發(fā)現(xiàn)核心概念其實(shí)特別簡(jiǎn)單,感興趣的小伙伴們可以參考一下
    2019-01-01
  • JavaScript 正則表達(dá)式與字符串查找方法

    JavaScript 正則表達(dá)式與字符串查找方法

    今天小編就為大家分享一篇JavaScript 正則表達(dá)式與字符串查找方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07

最新評(píng)論