RegExp对象表示正则表达式,它是对字符串执行模式匹配的工具。
正则表达式的基本语法如下:
1 直接量语法:/pattern/attributes
2 创建RegExp对象的语法: new RegExp(pattern, attributes);
参数:参数pattern是一个字符串,指定了正则表达式的模式;参数attributes是一个可选的参数,包含属性g,i,m, 分别代表:全局匹配,不区分大小写匹配,多行匹配
支持正则表达式的String对象的方法
1 search()方法 该方法用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的字符串
基本语法:stringObject.search(regxp);
@param参数regexp:可以是字符串,也可以是正则表达式。
@return 返回值:返回stringObject中第一个与regexp对象相匹配的子串的起始位置。如果没有找到任何匹配的字串,则返回-1;
注意:search()方法不执行全局匹配,它将忽略标准g,且总是从字符串开始位置进行查找,总是返回的是stringObject匹配到第一个位置。
var str = "hello world, hello world";
console.log(str.search(/hello/)); //0
console.log(str.search(/hello/g));//0
//没有全局概念 总是返回匹配到第一个位置
console.log(str.search("wo")); //6
//也可以是检索字符串中的字符
console.log(str.search(/longen/)); //-1
2 match()方法 该方法用于在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。
基本语法:stringObject.match(searchValue) 或stringObject.match(regexp)
@param(参数)
searchValue:需要检索字符串的值;
regexp: 需要匹配模式的RegExp对象;
@return 返回值:返回匹配成功的数组。如果没有找到任何的一个匹配,那么它将返回的是null; 返回的数组内有三个元素,第一个:匹配的文本,第二个:对象的属性,第三个:是对stringObject对象的引用。如果是全局匹配的话,它返回的是一个数组。
var str = "hello world";
console.log(str.match("hello"));
console.log(str.match(/hello/));
//["hello", index:0, input:"hello world"]
console.log(str.match("Hello")); //null
var str="1 plus 2 equal 3";
console.log(str2.match(/\d+/g));
//["1","2","3"]
3. replace()方法:该方法用于在字符串中使用一些字符替换另一些字符,或者替换一个正则表达式匹配的字符串;
基本语法:stringObject.replace(regexp/substr,replacement);
@param(参数)
regexp/substr:字符串或者需要替换模式的RegExp对象。
replacement:一个字符串的值,被替换的文本或者生成替换文本的函数。
@return(返回值) 返回替换后的新字符串
var str = "hello world";
var s1 = str.replace("hello","a");
console.log(s1); //a world
var s2 = str.replace(/hello/,"b");
console.log(s2); //b world
var s3 = str.replace(/l/g,' ');
console.log(s3); //heo word
4. split()方法:该方法把一个字符串分割成字符串数组
基本语法:stringObject.split(separator,howmany);
@param(参数)
1 separator[必填项],字符串或正则表达式,该参数指定的地方分割stringObject;
2 howmany[可选]该参数指定返回的数组的最大长度,如果设置了该参数,返回的子字符串不会多于这个参数指定的数组。如果没有设置该参数的话,整个字符串都会被分割,不考虑他的长度。
@return(返回值) 一个字符串数组。该数组通过在separator指定的边界处将字符串stringObject分割成子字符串。
var str ="what are you doing?";
console.log(str.split(" "));
//["what", "are", "you", "doing"]
console.log(str.split(""));
//["w", "h", "a", "t", " ", "a", "r", "e", " ", "y", "o", "u", " ", "d", "o", "i", "n", "g", "?"]
console.log(str.split("",3));
//["w", "h", "a"]
RegExp对象方法
1. test()方法:该方法用于检测一个字符串是否匹配某个模式;
基本语法:RegExpObject.test(str);
@param(参数) str是需要检测的字符串
@return(返回值) 如果字符串str中含有RegExpObject匹配的文本的话,返回true,否则返回false;
var str = "longen and yunxi";
console.log(/longen/.test(str));//true
console.log(/longlong/.test(str));//false
正则表达式中的字符
1 []含义
方括号包含一系列字符,能够匹配其中任意一个字符,如[abc]可以匹配abc中任意一个字符,使用[^abc]能够匹配abc字符之外的任何一个字符,只能是一个字符。如:
[abc]: 查找在方括号中的任意一个字符
[^abc]: 查找不在方括号中的任意一个字符
[0-9]: 查找0-9中的任意一个数字
[a-z]: 查找从小写a到z中的任意一个字符
2 元字符
. 查找任意的单个字符,除换行符外
\w 任意一个字母或数字或下划线,A_Za_z0-0
\W 查找非单词的字符,等价于[^A_Za_z0-9_]
\d 匹配一个数字字符,等价于[0-9]
\D 匹配一个非数字字符,等价于[^0-9]
\s 匹配任何空白字符,包括空格,制表符,换行符等等。等价于[\f\n\r\t\v]
\S 匹配任何非空白字符。等价于[^\f\n\r\t\v]
\b 匹配一个单词编辑,也就是单词和空格间的位置。
\B 匹配非单词边界
\n 匹配一个换行符
\f 匹配一个换页符
\r 匹配一个回车符
\t 匹配一个制表符
*3 需要转义的特殊字符前门加\ **
$ 匹配输入字符串的结尾位置,如果需要匹配本身的话,使用\$
^ 匹配输入字符串的开始位置,匹配本身的话,使用\
* 匹配前面的子表达式的零次或者多次,匹配本身的话,使用\*
+匹配子表达式的1次或者多次,匹配+本身的话,使用\+
. 匹配除换行符之外的任何一个字符,匹配本身的话,使用\.
[ 匹配一个中括号开始,匹配本身的,使用\[
? 匹配前面的子表达式的零次或者1次,或指明一个非贪婪限定符,要匹配本身的话,使用\?
\ 匹配本身的话,请使用\
{ 标记限定符开始的地方,要匹配{ ,请使用\{
| 指明多项中的一个选择,可以理解含义为或的意思,匹配本身的话,使用\|
了解量词
n+ 匹配任何至少包含一个n的字符串
n* 匹配零个或者多个n的字符串
n? 匹配零个或者1个n的字符串
n{x} 匹配包含x个n的序列化的字符串
n{x,y} 匹配至少x个,最多y个n的字符串
n{x,} 匹配至少x个的字符串
n$ 匹配以n结尾的字符串
^n 匹配以n开头的字符串
?=n 匹配其后紧跟指定的n字符串
?!n 匹配其后没有紧接指定的n字符串
正则表达式实战:
1 匹配以数字结尾的
/\d+$/g;
2 去掉空格
var str = "我 是 隆 恩";
console.log(str.replace(/\s+/g, ""));
3 判断字符串是不是由数字组成
var str = "123344我11223344";
console.log(/^\d*$/.test(str)); false
4 手机号码正则
手机号码需要匹配;手机号码开头不以0开始,并且是11位数字,目前的手机号码如下:13,14,15,17,18开头
/(^1[3|4|5|7|8][0-9]{9}$)/
5 删除字符串左右空格
function trim(str) {
return str.replace(/^\s+|\s+$/g,'');
}
var str1 = " 2345 ";
console.log(trim(str1));
6 限制文本框只能输入数字和小数点(二位小数点)
分析:开头有0个或者多个数字,中间有0个或者1个小数点,小数点后面有0个或者最多2个数字;
/^\d*\.?\d{0,2}$/
7 替换小数点前门的内容为指定内容
var href = "aa.php?d=1";
var reg = href.replace(/\b^(\w*)(?=\.)/,"bb");
console.log(reg); // bb.php?d=1