1.概述
    正则表达式是一个描述字符模式的对象。Javascript的正则表达式语法的是Perl5的正则表达式的子集。JS正则表达式有两种使用方式,文本模式和RegExp对象模式,实例如下:

var patern = /java/ig;    //文本模式
var patern = new RegExp(/java/, 'ig'); //对象模式

  注:ES3中RegExp共用一个对象,ES5每次调用产生一个新对象

2.正则表达式使用的主要字符和元字符
    2.1直接量字符
字符
匹配
字母和数字
自身
\o
NUL字符(\u0000)
\t
制表符(\u0009)
\n
换行符(\u000A)
\v
垂直制表符(\u000B)
\f
换页符(\u000C)
\r
回车符(\u000D)
\xnn
十六进制数,nn指拉丁字符
\uxxxxx
十六进制数,xxxx指unicode字符
\cX
控制字符^X

2.2字符类

字符
匹配
[...]
方括号内的任意字符
[^...]
除方括号外的任意字符
.
除换行符和其他unicode行终止符外的任意字符
\w
任何ASCII字符组成的单词,等价于[a-zA-Z0-9]
\W
非ASCII字符组成的单词,等价于[^a-zA-Z0-9]
\s
任何unicode空白符
\S
任何非unicode空白符
\d
任何ASCII数字,等价于[0-9]
\D
非ASCII数字,等价于[^0-9]
[\b]
退格直接量

2.3重复

字符
含义
{n,m}
匹配前一项,至少n次,不超过m次,[n,m)
{n,}
匹配前一项,至少n次或者更多次,[n,无穷)
{n}
匹配前一项n次,==n
?
匹配前一项,0到1次,0||1
+
匹配前一项,1到多次,[1,无穷)
*
匹配前一项,0次到多次,[0,无穷)

备注:非贪婪的重复,只需要在重复后面加一个?即可,目标是尽可能少的匹配。
    2.4选择、分组和引用字符

字符
含义
|
选择,匹配左边或者右边的表达式
(...)
分组,可使用重复符进行修饰(记忆)
(?:...)
只组合,不记忆
\n
和第n组,第一次匹配的字符相匹配

2.5指定匹配位置,即锚字符

字符 含义
^
匹配字符串的开头
$
匹配字符串的结尾
\b
匹配单词的边界符
\B
匹配单词非边界符
(?=p)
正向先行断言,都与p匹配但不包含
(?!p)
负向先行断言,都与p不匹配

2.6修饰符

字符
含义
i
不区分大小写
m
多行匹配模式
g
全局匹配

3.用于模式匹配的方法,包含String和RegExp对象

    3.1String提供了四种支持正则表达式的方法
方法名称
使用说明
String.search(patern)
返回第一个与之匹配的子串起始位置,如果找不到就返回-1
String.replace(patern, newStr)
将匹配的字符串替换成newStr,newStr也可以是动态替换字符串的函数
String.match(patern)
返回一个有匹配结果组成的数组,如果非全局匹配,第一个是匹配的字符串,后面为分组值
String.split(partern)
根据规则分割成数组

3.2RegExp提供两个方法

方法名称
使用说明
RegExp.exec(string)
和String的match方法返回值相同,RegExp.lastIndex是全局匹配的下一个匹配项的起始位置
RegExp.test(string)
当exec不为null时,返回true
4.正则表达式简单使用实例
匹配中文字符: [\u4e00-\u9fa5]
匹配首尾空格:(^\s*)|(\s*$)
//获取URL参数
var url = "http://www.cnblogs.com?func=window.getUserName&errno=0";
var splitUrlReg = /\?(\w+)=([^&=]*)(?:&(\w+)=([^&=]*))+/;;
var paramArr = url.match(splitUrlReg);
console.log(paramArr);
//["?func=window.getUserName&errno=0", "func", "window.getUserName", "errno", "0", index: 22, input: "http://www.cnblogs.com?func=window.getUserName&errno=0", clone: function]

  

  

 

初探JS正则表达式的更多相关文章

  1. JS正则表达式常用总结

    正则表达式的创建 JS正则表达式的创建有两种方式: new RegExp() 和 直接字面量. //使用RegExp对象创建 var regObj = new RegExp("(^\\s+) ...

  2. 从273二手车的M站点初探js模块化编程

    前言 这几天在看273M站点时被他们的页面交互方式所吸引,他们的首页是采用三次加载+分页的方式.也就说分为大分页和小分页两种交互.大分页就是通过分页按钮来操作,小分页是通过下拉(向下滑动)时异步加载数 ...

  3. 使用外部web组件-----easyUI、jQueryUI、Bootstrap、js正则表达式

    1.使用外部web组件,以Bootstrap为例 <head> <link rel='stylesheet'  href='bootstrap-3.3.0-dist/dist/css ...

  4. js正则表达式图形化工具-rline

    github地址:https://github.com/finance-sh/rline 在线demo: http://lihuazhai.com/demo/test.html 这是一个js正则表达式 ...

  5. Python之路-(js正则表达式、前端页面的模板套用、Django基础)

    js正则表达式 前端页面的模板套用 Django基础 js正则表达式: 1.定义正则表达式 /.../  用于定义正则表达式 /.../g 表示全局匹配 /.../i 表示不区分大小写 /.../m ...

  6. JS正则表达式大全

    转自:http://wenku.baidu.com/link?url=3y930kC7F6D3wQdMjQ3fVDmiA9Wfebs_QK0UB3N3mFaEoKg4ytZORPopxufeYA6si ...

  7. js正则表达式replace里有变量的解决方法用到RegExp类

    一直比较害怕使用正则表达式,貌似很深奥很复杂的样子,所以在用js操作字符串的时候,我最多使用的是replace.split.substring.indexOf等函数,这些函数有时候需要多次叠加使用,但 ...

  8. JS正则表达式验证账号、手机号、电话和邮箱

    JS正则表达式验证账号.手机号.电话和邮箱 效果体验:http://keleyi.com/keleyi/phtml/jstexiao/15.htm 验证帐号是否合法 验证规则:字母.数字.下划线组成, ...

  9. 初识JS正则表达式

    初识JS正则表达式 看到的使用的正则表达式练习:http://www.cnblogs.com/wenanry/archive/2010/09/06/1819552.html PS:本文参考李炎恢JS笔 ...

随机推荐

  1. [置顶] js对象

    js中,一切事物都是对象.对象是一切的基础. 而具体到某一个对象时. 对象则是包含一组变量和函数的集合实例 我们先来中体会下je对象的全局. 接下来就具体揭开这个对象的面纱吧 ja对象分类 Funct ...

  2. loadrunner java 缺少必要的导入包报错

    loadrunner 运行从eclipse中做好的脚本,ctrl + A 复制到loadrunner中来, 添加参数化的的语句:verifyCode =    lr.eval_string (&quo ...

  3. python calendar标准库基础学习

    # -*- coding: utf-8 -*-# 作者:新手__author__ = 'Administrator'#标准库:日期时间基础学习:calendar:处理日期#例1import calen ...

  4. java 自定义鼠标图标

    由于截图截不了,所以看不了图.源码如下: import java.awt.Cursor; import java.awt.Image; import java.awt.Point; import ja ...

  5. 免费邮件服务器:MailEnable

    官方网站地址:www.mailenable.com 下载最新版的 Standard Edition (FREE) 安装之前请留意安装指引就可以了,安装上去之后,直接就可以使用了 安装指引上写的清清楚楚 ...

  6. AVR32开发环境搭建

    下面是搭建AVR32开发环境的过程记录: 1.AVR32的编译环境下载  (到这里下载  as5installer-stable-5.1.208-full.exe) 如果你在安装的过程中碰到如下问题: ...

  7. Cortex-A9 PWM Timer

    PWM定时器        4412时钟为我们提供了PWM定时器,在4412中共有5个32位的定时器,这些定时器可发送中断信号给ARM子系统.另外,定时器0.1.2.3包含了脉冲宽度调制(PWM),并 ...

  8. HTML与CSS入门——第七章 使用表格显示信息

    知识点: 1.创建简单表格的方法 2.控制表格大小的方法 3.对齐内容及在表格中跨越行和列的方法 7.1 创建简单的表格: table标签,border控制边框 tr标签,创建表格的行,包含td td ...

  9. cocoa pods 安装 转载

    1.打开终端 终端输入  $ruby -v  查看ruby的版本 打印代码: ruby 2.0.0p648 (2015-12-16 revision 53162) [universal.x86_64- ...

  10. vc 获取当前时间

    1.使用CTime类 CString str; //获取系统时间 CTime tm; tm=CTime:: GetCurrentTime_r(); str=tm.Format("现在时间是% ...