1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關(guān)咨詢(xún)
      選擇下列產(chǎn)品馬上在線(xiàn)溝通
      服務(wù)時(shí)間:8:30-17:00
      你可能遇到了下面的問(wèn)題
      關(guān)閉右側(cè)工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
      怎么實(shí)現(xiàn)正則表達(dá)式的JavaScript代碼高亮-創(chuàng)新互聯(lián)

      這篇文章主要介紹怎么實(shí)現(xiàn)正則表達(dá)式的JavaScript代碼高亮,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

      成都創(chuàng)新互聯(lián)公司提供成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、外貿(mào)營(yíng)銷(xiāo)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì),品牌網(wǎng)站建設(shè)廣告投放等致力于企業(yè)網(wǎng)站建設(shè)與公司網(wǎng)站制作,10年的網(wǎng)站開(kāi)發(fā)和建站經(jīng)驗(yàn),助力企業(yè)信息化建設(shè),成功案例突破上千,是您實(shí)現(xiàn)網(wǎng)站建設(shè)的好選擇.

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

      /(\/\/.*|\/\*[\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)的。現(xiàn)在,我們把它用|分割,逐個(gè)分析。

      (\/\/.*|\/\*[\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è)非獲取匹配。

      \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ò)。

      (?:[^\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),任意次。這樣變量名就被消耗掉了。

      (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á)式的范疇,所以我們要匹配并獲取它。

      [\S\s]

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

      
      

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

      以上是“怎么實(shí)現(xiàn)正則表達(dá)式的JavaScript代碼高亮”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


      網(wǎng)站欄目:怎么實(shí)現(xiàn)正則表達(dá)式的JavaScript代碼高亮-創(chuàng)新互聯(lián)
      網(wǎng)站網(wǎng)址:http://www.ef60e0e.cn/article/idodj.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        苏尼特左旗| 罗田县| 长治县| 奉节县| 辽宁省| 米脂县| 嘉善县| 文登市| 小金县| 白朗县| 上蔡县| 衡水市| 家居| 宁南县| 湘潭县| 辽阳县| 瑞金市| 法库县| 安塞县| 随州市| 庆城县| 库尔勒市| 吴堡县| 奇台县| 云林县| 千阳县| 铜梁县| 定襄县| 彰化市| 恩施市| 祥云县| 新干县| 乌拉特中旗| 池州市| 岳西县| 济南市| 和田县| 湟中县| 德阳市| 涟水县| 安仁县|