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

首頁 > 開發 > JS > 正文

實現JavaScript代碼高亮的方法

2024-09-06 12:41:27
字體:
來源:轉載
供稿:網友

當我們想要修改js的高亮配色的時候我們要怎么辦呢?文中小編根據自己的經驗想出實現JavaScript代碼高亮的方法,感興趣的小伙伴們一起跟小編去看看吧。
  下面這老長老長了的玩意兒是個正則表達式,看到了別嚇壞了。

?

?

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

?

  以上就是小編為大家分享實現JavaScript代碼高亮的方法,應該還有很多小漏洞,不過整體思路就是這樣。這樣無論是JS還是其它什么語言,代碼高亮都可以直接正則匹配出來。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本一区二区三区四区视频| 中文字幕日韩欧美在线| 久久久91精品国产| www.日韩系列| 久久亚洲电影天堂| 91精品国产成人www| 亚洲图片制服诱惑| 国产精品视频地址| 亚洲女人被黑人巨大进入al| 国产精品青青在线观看爽香蕉| 欧美性一区二区三区| 2019中文字幕全在线观看| 亚洲第一区第一页| 国产精品久久久久久久久免费| 亚洲人a成www在线影院| 欧美午夜精品久久久久久人妖| 国产网站欧美日韩免费精品在线观看| 2019中文字幕全在线观看| 97视频在线观看免费| 中文字幕日本精品| 91精品国产色综合久久不卡98口| 另类美女黄大片| 日韩欧美在线播放| 乱亲女秽乱长久久久| 国产成人精品视频| 岛国av一区二区三区| 色婷婷综合久久久久中文字幕1| 深夜福利一区二区| 成人黄色av网站| 91视频九色网站| 欧美激情啊啊啊| 欧美日韩xxx| 成人黄色短视频在线观看| 57pao成人国产永久免费| 在线电影欧美日韩一区二区私密| 日韩成人av在线播放| 亚洲最大的成人网| 亚洲欧美日韩另类| 91av在线国产| 在线视频中文亚洲| 一本大道香蕉久在线播放29| 色青青草原桃花久久综合| 久久久伊人欧美| 亚洲图片在区色| 欧美成人免费在线视频| 色婷婷av一区二区三区在线观看| 97视频在线观看播放| 亚洲激情第一页| 疯狂蹂躏欧美一区二区精品| 久久免费视频观看| 亚洲视频电影图片偷拍一区| 国产乱人伦真实精品视频| 欧美精品日韩三级| 97精品一区二区视频在线观看| 国内精品久久久久影院优| 91免费的视频在线播放| 美日韩丰满少妇在线观看| 亚洲精品www久久久久久广东| 久青草国产97香蕉在线视频| 日韩欧美在线免费| 欧美电影免费看| 亚洲欧美国产精品专区久久| 欧美一级在线播放| 精品免费在线观看| 伊人成人开心激情综合网| 久久人人爽人人爽人人片av高请| 成人福利网站在线观看11| 美女久久久久久久久久久| 国产精品美女www爽爽爽视频| 国产精品天天狠天天看| 日韩在线观看精品| 欧美日韩在线视频观看| 国产亚洲欧洲黄色| 欧美一区二区大胆人体摄影专业网站| 亚洲综合精品伊人久久| 国产成人jvid在线播放| 91中文精品字幕在线视频| 亚洲电影第1页| 2020国产精品视频| 久久精品国产69国产精品亚洲| 欧美日韩加勒比精品一区| 国产国语videosex另类| 91精品国产成人| 久久艹在线视频| 久久久久久久久电影| 亚洲性生活视频| www高清在线视频日韩欧美| 欧美一区二区三区四区在线| 亚洲理论在线a中文字幕| 国产在线观看一区二区三区| 午夜精品久久久久久久白皮肤| 成年人精品视频| 亚洲欧洲成视频免费观看| 91中文字幕在线| 久久精品视频免费播放| 色偷偷888欧美精品久久久| 免费不卡在线观看av| 久久久久久一区二区三区| 97视频com| 日韩毛片在线看| 久久久亚洲国产| 国产999视频| 欧美三级免费观看| 91精品国产乱码久久久久久蜜臀| 永久555www成人免费| 国产午夜精品全部视频播放| 亚洲欧美中文日韩v在线观看| 欧美成人高清视频| 亚洲精品mp4| 亚洲综合精品伊人久久| 国产精品一区二区久久| 欧美电影在线观看高清| 91精品国产高清自在线| 精品国产欧美成人夜夜嗨| 国模精品视频一区二区三区| 日韩精品丝袜在线| 国产精品毛片a∨一区二区三区|国| 日韩欧美一区二区在线| 成人黄色免费片| 91欧美日韩一区| 国产一区二区日韩| 精品视频在线观看日韩| 日韩亚洲第一页| 欧美亚洲国产另类| 国产精品69av| 欧美一区三区三区高中清蜜桃| 麻豆国产va免费精品高清在线| 日本午夜精品理论片a级appf发布| 亚洲第一区中文99精品| 亚洲最新av在线网站| 中文字幕久久久| 国产精品美女主播在线观看纯欲| 国产精品扒开腿爽爽爽视频| 91久久国产精品91久久性色| 久久免费少妇高潮久久精品99| 久久久久久久一| 日韩在线视频观看| 91精品国产91久久久久福利| 国产精品久久久亚洲| 久久夜色精品国产| 欧美另类第一页| 国产欧美va欧美va香蕉在| 亚洲乱码国产乱码精品精天堂| 在线电影中文日韩| 亚洲一级黄色av| 亚洲男人天堂久| 久久精品久久久久电影| 欧美黑人极品猛少妇色xxxxx| 亚洲欧洲国产伦综合| 久久精品国产视频| 亚洲成人精品久久| 亚洲va久久久噜噜噜| 高清欧美性猛交| 久久久91精品国产一区不卡| 欧美大片免费观看在线观看网站推荐| 日本在线精品视频| 大荫蒂欧美视频另类xxxx| 欧美日韩国产中字| 国产精品吹潮在线观看| 欧美高清无遮挡| 狠狠躁夜夜躁人人爽天天天天97| 日韩在线观看免费全集电视剧网站| 日韩成人高清在线| 欧美成人免费视频|