语法
/pattern/modifiers; //modifiers: g全局匹配,i敏感选择器(区分大小写)
var reg = /a/g
eg:
str = "Please visit Microsoft!";
var n = str.replace(/MICROSOFT/i, "W3Schools"); //Please visit W3Schools
eg:
str = "Please visit Microsoft and Microsoft!";
var n = str.replace(/Microsoft/g, "W3Schools"); //Please visit W3Schools and W3Schools
支持正则表达式字符串中的方法
test()
检索字符串,看是否有指定的值,返回true或false
var reg = /l/g;
var a = "hello world";
reg.test(a); //true
//test() 只要字符串中的一部分符合要求
exec()
检索字符串中指定的值,返回值,并指明其下标
var reg = /l/g;
var a = "hello world";
reg.exec(a); // ["l", index: 2, input: "hello world"]
search()
索引指定的值,返回其下标
var reg = /l/g;
var txt = "hello word";
txt.search(reg); //2
//注释:如果没有找到任何匹配的子串,则返回 -1
replace()
替换与正则匹配的值
var reg = /l/g;
var txt = "hello word";
txt.replace(reg,"*"); //he**o word
match()
返回所有与正则匹配的值
var reg = /l/g;
var txt = "hello word";
txt.match(reg); // ["l", "l"]
split()
通过指定的值把字符串分隔成数组
var reg = /l/g;
var txt = "hello word";
txt.split(reg); // ["he", "", "o word"]
备选字符集:规定某一位字符的备选字符列表
特点:必须且只能多选一
eg:上天,上海
上[天海]
如果备选字符的unicode号连续
//一个数字
[0-9]
//一个小写字母
[a-z]
//一个大写字母
[A-Z]
//一位数字、字母或下划线
[0-9a-zA-Z_]
预定义字符集:针对常用的备选字符集提供的简化符号
//一位数字
[0-9] --> \d
//一位数字、字母或下划线
[0-9a-zA-Z_] -->\w
//1位空字符:换行符,制表符,空格,回车,
\s
//边界
\b
// 除空格、换行外,其余所有字符
.
量词:规定字符集出现的次数
确定数量:
{m,n} -->至少m个,最多n个
{m,} -->m个以上
{m} -->必须m个
不确定数量:
? -->0或1个
+ -->1个以上
* -->多个或没有
选择和分组
//选择
| 读作"或"
//分组
()
手机号
手机号:+86或0086 可有可无,最多1个
空字符 不限制个数
1
3,4,5,7,8 选其一
9位数字
(\+86|0086)?\s*1[34578]\d{9}
指定匹配位置
开头和结尾:^开头的xxx;$结尾的xxx
何时使用:仅匹配开头的规则和结尾的规则时使用
固定搭配:^正则表达式$-->表示从头到尾完整匹配
何时使用:只要验证时,必须前加^,后加$!
eg:
//匹配字符串开头的所有空字符
^\s+
//匹配字符串结尾的所有空字符
\s+$
排除
//除了abc
[^abc]
实例
关键词过滤
//将句子里的北京和淘宝替换成"***"
//HTML
<textarea id="txt1" name="" cols="30" rows="10">
</textarea>
<input type="button" value="过滤" id="btn" />
<textarea id="txt2" name="" cols="30" rows="10">
</textarea>
//JS
window.onload = function(){
var txt1 = document.getElementById("txt1");
var txt2 = document.getElementById("txt2");
var btn = document.getElementById("btn");
btn.onclick=function(){
var value = txt1.value;
var reg = /淘宝|百度/g;
txt2.value = value.replace(reg,"***")
}
}
过滤HTML标签
var reg =/<[^<>]+>/g;
txt2.value = txt1.value.replace(reg,"");
//HTML
<input type="text" id="input"><span id="span"></span>
//JS
var reg = /^\w+@[a-z0-9]+\.com$/g;
var input = document.getElementById("input");
var span = document.getElementById("span");
input.onchange = function(){
var value = this.value;
if(value.match(reg)){
span.innerHTML = "通过";
}else{
span.innerHTML = "错误,请重新输入";
}
}
数字每隔3为加逗号‘,’
var str = '1000000000';
var reg = /(?=(\B)(\d{3})+$)/g;
var strNum = str.replace(reg, ',');