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

首頁 > 編程 > regex > 正文

幾個小例子教你如何實現正則表達式highlight高亮

2020-01-20 22:12:16
字體:
來源:轉載
供稿:網友

程序員在編寫代碼的時候少不了和字符串以及“查詢”打交道,兩者的交集中有一個叫做正則表達式的的東西,這家伙用好了可以提高編程效率,用不好的話...你可以先去好好學一學。

  關于正則的使用,舉個簡單的例子:

復制代碼 代碼如下:

var m = location.href.match(/(/w+:)//{0,3}([^//]+)(?:(//[^/?#]*))?(?:(/?[^#]+|.+))?(?:(#.*))?/);
var res = {
    protocol: m[1],
    host: m[2],
    path: m[3],
    search: m[4],
    hash: m[5]
};
console.log(res);

  憋了幾分鐘= =||,我也覺得這個正則不是特別好理解(紅黑相間了,應該稍微清晰點),有些朋友可能不知道(?:content)是什么意思,還有類似(?!content)和(?=content)分組和前瞻的知識,建議去問問度哥和谷娘。


一. 正則應用小DEMO示例

下面是一串隨手寫的代碼,放在textarea中:

復制代碼 代碼如下:

/**
* @author barret lee
* @date   2013-10-06
* @email  barret.china@gmail.com
*/

//outer var
var a = "this id outer string";

//closure
function b() {
 //inner var
 var a = "this is inner string";
 var g = a.replace(/this is inner string/g, function() {
  return new Function("/*clousure*/this.a")();
 });

 /**
 * @description closure - regExp test
 * @author barret lee
 */
 function c() {
  return {
   a: a,
   g: g
  }
 }

 return c;
}

var s = b()(); //s.a, s.g

正則匹配,處理上面那堆字符串的小DEMO:

復制代碼 代碼如下:

/**
* @author barret lee
* @date 2013-10-06
* @email barret.china@gmail.com
*/

//outer var
var a = "this id outer string";

//closure
function b() {
    //inner var
    var a = "this is inner string";
    var g = a.replace(/this is inner string/g, function() {
        return new Function("/*clousure*/this.a")();
    });

    /**
    * @description closure - regExp test
    * @author barret lee
    */
    function c() {
        return {
            a: a,
            g: g
        }
    }

    return c;
}

var s = b()(); //s.a, s.g

跟著提示,下一步下一步多點幾下,可以看出效果還是可以滴。主要是這里的正則略微的麻煩,處理一個色變得琢磨老半天。

P.S:上面這玩意兒只是一個小測試,代碼相當不健壯,拿著學習正則練手~

二. 需要注意的地方

復制代碼 代碼如下:

//step config
var config = {
    regs: [
        /^/s+|/s+$/g,
        /(["'])(?://.|[^///n])*?/1/g,
        ///(?!/*|span).+//(?!span)[gim]*/g,
        /(////.*|///*[/S/s]+?/*//)/g,
        /(/*/s*)(@/w+)(?=/s*)/g,
        //b.../b/g
    ],
  //...
};

這些正則我是分開來寫的,主要是為了做上面那個demo,方便單步顯示。但是把這些正則分開寫是相當不合理的,放在textarea中的是一串沒有任何標簽的字符串,為了著色,每處理一個正則都會在codes中插入一些標簽(我這里用的是span),當我們處理下一個正則的時候就必須得考慮上一步加入的標簽,這樣會很大程度提高開發難度,最好的做法是把這些正則都放到一坨,然后用|隔開:

復制代碼 代碼如下:

var reg = (/^/s+|/s+$/)|(/(["'])(?://.|[^///n])*?/1/)|(///(?!/*|span).+//(?!span)[gim]*/)|(/(////.*|///*[/S/s]+?/*//)/)|(/(/*/s*)(@/w+)(?=/s*)/)|(//b(break|continue|do|for|in|function|if|else|return|switch|throw|try|catch|finally|var|while|with|case|new|typeof|instance|delete|void|Object|Array|String|Number|Boolean|Function|RegExp|Date|Math|window|document|navigator|location|true|false|null|undefined|NaN)/b)

這樣放的好處是可以直接

復制代碼 代碼如下:

codes.replace(reg, function(){
    var args = arguments;
    //...
});

一次性處理,不用擔心插入標簽影響最后的結果,因為標簽是同一時間插入的,不會有干擾。

代碼高亮插件highlight的基本原理也差不多,只不過他的容錯機制和代碼健壯性這塊做的更加完善,我在代碼里頭加了一個配置文件,

復制代碼 代碼如下:

var colors = {
    string: "#FFA0A0",
    reg: "#16E916",
    note: "#888",
    tag: "orange",
    keywords: "#B0B0FF"
};

按照自己的喜好,也可以加以修改,類似這樣的擴展,我們在寫代碼的時候稍微注意下,多留幾個接口就好了。(不過這些活兒干起來都還挺辛苦的~)

沒有做成插件,也沒這個必要,知道基本原理然后動手實踐下就差不多了。

三. 小結

類似很多的前端模板,artTemplate,baiduTemplate等都是對正則表達式的絕倫應用,很值得去看看源碼,好好鉆研人家都考慮了那些容易出錯的點,源碼都不長,兩三百行。了解一個大概比較容易,但是當自己動手的時候總會發現很多細節問題處理不好,我那上面幾個正則就倒弄了半天= =

正則表達式,用起來還是挺方便的。正則技能,你值得擁有~

 

 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产成人| 欧美性一区二区三区| 中文字幕一区二区三区电影| 国产综合在线观看视频| 欧美午夜片欧美片在线观看| 国产性色av一区二区| 国产精品视频内| 免费不卡欧美自拍视频| 亚洲黄色在线看| 久久成人18免费网站| 久久激情视频久久| 亚洲第一免费网站| 日韩中文字幕在线观看| 国产91精品久久久久| 国产精品亚洲自拍| 粗暴蹂躏中文一区二区三区| 日韩中文字幕av| 亚洲美女又黄又爽在线观看| 中文字幕亚洲自拍| 欧美激情一区二区三区在线视频观看| 91免费在线视频网站| 一区二区三欧美| 亚洲第一福利网站| 中文字幕久精品免费视频| 国产日韩中文字幕在线| 亚洲成人激情在线| 国产日韩欧美电影在线观看| 国产mv免费观看入口亚洲| 51色欧美片视频在线观看| 国产成人精品网站| 国产日韩欧美一二三区| 日韩av中文字幕在线免费观看| 亚洲欧美激情视频| 亚洲有声小说3d| 456亚洲影院| 日韩av电影手机在线观看| 97视频在线观看网址| 91最新在线免费观看| 欧美大胆a视频| 不卡伊人av在线播放| 亚洲第一区在线| 日韩视频在线免费观看| 国产乱肥老妇国产一区二| 人人澡人人澡人人看欧美| 成人做爰www免费看视频网站| 亚洲精选在线观看| 久久婷婷国产麻豆91天堂| 亚洲品质视频自拍网| 国产精品av在线播放| 久久躁日日躁aaaaxxxx| 亚洲在线免费看| 国产精品福利在线| 欧美日韩成人网| 欧美影院在线播放| 欧美午夜性色大片在线观看| 最新中文字幕亚洲| 欧美成年人视频网站欧美| 丰满岳妇乱一区二区三区| 成人福利网站在线观看| 欧美国产亚洲精品久久久8v| 日韩av在线免费观看| 精品视频中文字幕| 久久韩剧网电视剧| 奇米一区二区三区四区久久| 久久久亚洲国产| 91精品国产九九九久久久亚洲| 95av在线视频| 久久久噜久噜久久综合| 91亚洲国产成人精品性色| www.欧美精品一二三区| 91日本视频在线| 久久婷婷国产麻豆91天堂| 精品中文字幕乱| 中国人与牲禽动交精品| 不卡av在线网站| 一区二区三区在线播放欧美| 91chinesevideo永久地址| 国产成人精品免高潮费视频| 亚洲人成电影在线播放| 亚洲免费电影一区| 亚洲电影成人av99爱色| 国产成人亚洲精品| 亚洲免费电影一区| 日韩在线视频一区| 久色乳综合思思在线视频| 欧美一级视频一区二区| 精品自拍视频在线观看| 国产成人综合久久| 日韩视频永久免费观看| 亚洲精品按摩视频| 亚洲大胆美女视频| 亚洲精品久久久久久久久久久久久| 亚洲一级片在线看| 亚洲免费一在线| 2020欧美日韩在线视频| 国产不卡av在线| 国产在线拍偷自揄拍精品| 亚洲黄色www网站| 亚洲国产精品久久久久秋霞不卡| 国产一区二区色| 成人免费淫片视频软件| 日韩电视剧在线观看免费网站| 日韩欧美中文字幕在线播放| 欧美在线视频网站| 国产精品福利观看| 2023亚洲男人天堂| 岛国视频午夜一区免费在线观看| 久久久久久久久久久网站| 中文字幕欧美亚洲| 欧美激情精品在线| 国内精品模特av私拍在线观看| 久久久视频免费观看| 亚洲一品av免费观看| 久久久久久有精品国产| xvideos成人免费中文版| 疯狂欧美牲乱大交777| 国产成人自拍视频在线观看| 亚洲免费中文字幕| 97婷婷涩涩精品一区| 国产成人精品久久二区二区91| 欧美日韩激情小视频| 欧美午夜激情小视频| 91中文精品字幕在线视频| 欧美视频专区一二在线观看| 91视频九色网站| 日本精品性网站在线观看| 亚洲视频一区二区三区| 国产午夜精品美女视频明星a级| 91沈先生在线观看| 亚洲一区二区三区在线免费观看| 国产精品成人一区二区| 国产精品久久久久久久美男| 久久夜色精品国产| 国产精品久久久久7777婷婷| 国产精品欧美激情| 中文字幕亚洲综合| 韩国国内大量揄拍精品视频| 亚洲精品一区av在线播放| 欧洲亚洲在线视频| 久久在线精品视频| 欧美国产日韩二区| 欧美性做爰毛片| 日韩精品小视频| 国产精品网站视频| 国产一区视频在线播放| 久久免费视频这里只有精品| 成人妇女淫片aaaa视频| 日韩h在线观看| 91精品国产电影| 91沈先生在线观看| 色偷偷偷综合中文字幕;dd| 亚洲一区二区精品| www欧美xxxx| 91精品国产自产在线观看永久| 伊人久久免费视频| 日韩精品中文字幕在线播放| 久久久成人的性感天堂| 91超碰中文字幕久久精品| 精品成人久久av| 日韩激情视频在线播放| 欧美高清在线视频观看不卡| 亚洲成人av片在线观看| 欧美有码在线观看视频| 永久免费看mv网站入口亚洲|