1、实例化正则表达式对象
构造函数
var pattern=new RegExp("正则表达式","模式");
字面量
var pattern= /正则表达式/模式;
2、模式
i ignore case 不区分大小写
g global 全局
m multiline 多行
3、正则表达式对象
pattern.lastIndex 下一次匹配的开始位置
pattern.source 正则表达式文本
pattern.flags 模式
pattern.input 原始字符串
pattern.leftContext 捕捉到的位置的左边字符串
pattern.rightContext 捕捉到位置的右边的字符串
pattern.lastMatch 返回最近一次与整个正则表达式匹配的字符串
pattern.lastParen 返回最近一次捕捉的字符
pattern.exec() 从参数中获取目的字符串
返回值:类数组对象
pattern.test() 只要存在匹配返回true,否则返回false
var pattern=/java/I;
pattern.test(“JavaScript”)
4、字符串对象
seach() 第一个与之匹配的子串的起始位置,找不到则返回-1
“JavaScript”.search(/script/i)
返回4
replace() 替换后的字符
text.replace(/javascript/gi,“JavaScript”)
match() 由匹配结果组成的数组,未匹配则返回null
“1 plus 2 equals 3”.match(/\d+/g)
返回[“1”, “2”, “3”]
split() 拆分后的子串数组
“123,456,789”.split(“,”)
返回[“123”, “456”, “789”]
5、正则表达式的字符含义
\ 做为转义,即通常在"“后面的字符不按原来意义解释,如/b/匹配字符"b”,当b前面加了反斜杆后/\b/,转意为匹配一个单词的边界。
-或-
对正则表达式功能字符的还原,如""匹配它前面元字符0次或多次,/a/将匹配a,aa,aaa,加了"“后,/a*/将只匹配"a*”。
^ 匹配一个输入或一行的开头,/^a/匹配"an A",而不匹配"An a"
$ 匹配一个输入或一行的结尾,/a$/匹配"An a",而不匹配"an A"
- 匹配前面元字符0次或多次,/ba*/将匹配b,ba,baa,baaa
- 匹配前面元字符1次或多次,/ba*/将匹配ba,baa,baaa
? 匹配前面元字符0次或1次,/ba*/将匹配b,ba
(x) 匹配x保存x在名为$1…$9的变量中
x|y 匹配x或y
{n} 精确匹配n次
{n,} 匹配n次以上
{n,m} 匹配n-m次
[xyz] 字符集(character set),匹配这个集合中的任一一个字符(或元字符)
[^xyz] 不匹配这个集合中的任何一个字符
[\b] 匹配一个退格符
\b 匹配一个单词的边界
\B 匹配一个单词的非边界
\cX 这儿,X是一个控制符,/\cM/匹配Ctrl-M
\d 匹配一个字数字符,/\d/ = /[0-9]/
\D 匹配一个非字数字符,/\D/ = /[^0-9]/
\n 匹配一个换行符
\r 匹配一个回车符
\s 匹配一个空白字符,包括\n,\r,\f,\t,\v等
\S 匹配一个非空白字符,等于/[^\n\f\r\t\v]/
\t 匹配一个制表符
\v 匹配一个重直制表符
\w 匹配一个可以组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[\w]匹配"$5.98"中的5,等于[a-zA-Z0-9]
\W 匹配一个不可以组成单词的字符,如[\W]匹配" 5.98 " 中 的 5.98"中的 5.98"中的,等于[^a-zA-Z0-9]。
6、重复
/\w{3}/ 3个连续字符
{1,4}
{1,}
{1}
“+” 相当于{1,}
“*” 相当于 {0,}
?等价于{0,1}
var pattern =/([a-z]{3,5}):\/\/([0-9a-z.]{2,})(:\d{2,6})?(\/.*)/igm;
var str = "静态网页地址:http://134.175.154.93/lianjia";
console.log(str);
var result;
while((result = pattern.exec(str)) !== null){
console.log(result);
console.log('url',result[0]);
console.log('proxy',result[1]);
console.log('ip',result[2]);
console.log('port',result[3]);
}