• 谈谈我对正则表达式的认识


    
    ##文章定位(目标读者)
    * 听说过**正则表达式**,见过其使用的场合,但未能熟练掌握起来]的人
    * 至少看过一遍[正则表达式30分钟入门教程](http://deerchao.net/tutorials/regex/regex.htm)但未能完全掌握的人。
    
    
    
    
    ##正则表达式是什么
    **正则表达式(Regular Expression)**是一个概念,一种语法、句法的约定。每一种具体的语句(C#,Java,JavaScript)有其对于`正则表达式`的具体实现,并且会有差别。[正则表达式30分钟入门教程](http://deerchao.net/tutorials/regex/regex.htm)讲述的是.net(C#)的正则表达式。
    
    
    
    
    ##JavaScript的正则表达式
    本人擅长的是JavaScript的正则表达式,这种正则表达式一个最大的特点是不支持`零宽度正回顾后发断言`,原因很简单,js是解释执行的。细节等深入后再去理解。
    
    
    
    
    ##语法查询
    * [正则表达式30分钟入门教程](http://deerchao.net/tutorials/regex/regex.htm)
    * [JavaScript RegExp 对象参考手册](http://www.w3school.com.cn/js/jsref_obj_regexp.asp)
    * [JavaScript String 对象参考手册](http://www.w3school.com.cn/js/jsref_obj_string.asp)中的部分方法例如`match`,`replace`,`search`。
    
    
    
    
    
    ##应用场景
    正则表达式有两大应用场景
    1. 检测用户的输入是否合法;
    2. 从一堆信息中提取出自己想要的部分信息;
    这两大应用场景最大的区别是,检测输入的合法性是针对整个输入字符的,即要加上
    `^`去匹配字符串的开始及`$`去匹配字符串的结束,否则意义不大,至少本人还没遇到过不加上的情景。而提取信息的场景一般涉及到全局搜索`g`
    
    
    
    
    ##简单的例子
    光是看代码,怎么也掌握不了正则表达式的,下面我们来实践一下:
    打开chrome(如果你还没安装chrome,那你不能算是本文的目标读者),当然安装了firebug的firefox或者高版本的IE也OK,,按`F12`,调出开发人员工具。
    切换到如下的选项卡,输入代码
    
    ```javascript
    /Hello World/.test("Hello World")
    ```
            
    ![Hello World 示例代码](https://images0.cnblogs.com/blog/84053/201402/020019328759145.jpg)
    
    OK,以上代码就是用一个正则表达式去检测一个字符串是否包含"Hello World"这个特定字符。
    在JS中,最常用的就是Regexp的直接量,即在两条斜杠`//`中加上正则表达式的语法。也就是说,在[正则表达式30分钟入门教程](http://deerchao.net/tutorials/regex/regex.htm)提及到的语法例如`[aeiou]`、`(?0d{2}[) -]?d{8}`等等,置于两条斜杠`//`中就成为一个JS的正则表达式对象(`/[aeiou]/`、`/(?0d{2}[) -]?d{8}/`),就拥有[JavaScript RegExp 对象参考手册](http://www.w3school.com.cn/js/jsref_obj_regexp.asp)中提到的方法,也能应用到[JavaScript String 对象参考手册](http://www.w3school.com.cn/js/jsref_obj_string.asp)的部分方法中,才能应用到实际编程中,具体参考上面的Hello World 示例代码。
    最后,根据我自己的经验,要自己去做一个实践,例如
    
    1. 把本篇文章中body部分的内容提取出来,或者把所有的超连接中的文字提取出来
    
    2. 设计一个表单,验证用户的输入,具体的验证可以参考[常用正则表达式](http://deerchao.net/tutorials/regex/common.htm)
    
    
    
    
    ##最后的话
    以上是我本人学习正则表达式的一些体会,当时的体会就是:看到了很多语法细节,但不知道如何付诸实践,在自己进行了一个小实践后,终于明白。在此进行整理。
  • 相关阅读:
    CSS3中制作倒影box-reflect
    JS中==与===区别
    CSS3-Animation
    CSS3-transform
    CSS3-transition
    CSS盒模型-box-sizing
    css兼容处理-hack
    CSS3-rgba
    CSS3-文本-word-wrap,word-break,white-space
    CSS3-文本-text-shadow
  • 原文地址:https://www.cnblogs.com/p2227/p/3537160.html
Copyright © 2020-2023  润新知