• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    几个小例子教你如何实现正则表达式highlight高亮

    程序员在编写代码的时候少不了和字符串以及“查询”打交道,两者的交集中有一个叫做正则表达式的的东西,这家伙用好了可以提高编程效率,用不好的话...你可以先去好好学一学。

      关于正则的使用,举个简单的例子:

    复制代码 代码如下:

    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等都是对正则表达式的绝伦应用,很值得去看看源码,好好钻研人家都考虑了那些容易出错的点,源码都不长,两三百行。了解一个大概比较容易,但是当自己动手的时候总会发现很多细节问题处理不好,我那上面几个正则就倒弄了半天= =

    正则表达式,用起来还是挺方便的。正则技能,你值得拥有~

     

     

    您可能感兴趣的文章:
    • 用正则表达式格式化html标签的代码
    • 正则表达式搭配js轻松处理json文本方便而老古
    • 如何使用Javascript正则表达式来格式化XML内容
    • 如何实现正则表达式的JavaScript的代码高亮
    • js 玩转正则表达式之语法高亮
    • 使用正则表达式的格式化与高亮显示json字符串
    上一篇:JS 正则表达式用法介绍
    下一篇:如何实现正则表达式的JavaScript的代码高亮
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    几个小例子教你如何实现正则表达式highlight高亮 几个,小,例子,教你,如何,