关于javascript:JavaScript基础8-正则及相关语法

5次阅读

共计 4618 个字符,预计需要花费 12 分钟才能阅读完成。

正则表达式的简介

正则表达式用于定义一些字符串的规定
计算机能够依据正则表达式来查看一个字符串是否合乎规定
将字符串中合乎规定的内容取出来

语法:

var 变量 = new RegExp("正则表达式","匹配模式");

应用 typeof 查看正则对象,会返回 object。var reg = new RegExp(“a”); 这个正则表达式用来测验是否含有 a

var reg = new RegExp();
console.log(typeof reg)                        //object

正则表达式的办法
test()
应用这个办法能够用来查看一个字符串是否合乎正则表达式的规定
如果合乎则返回 true,否则返回 false

var reg = new RegExp("a");
var str = "a";
var result = reg.test(str);
console.log(result);                        //true
console.log(reg.test("bcdA"));                    //false
console.log(reg.test("bcd"));                    //false
console.log(reg.test("bcad"));                    //true

在构造函数中能够传递一个匹配模式作为第二个参数
能够是 g: 全局匹配模式,i:疏忽大小写
i: 疏忽大小写

var reg = new RegExp("a","i");                    
console.log(reg.test("bcad"));                    //true
console.log(reg.test("bcdA"));                    //true

正则语法

应用字面量来创立正则表达式
语法:

var 变量 = / 正则表达式 / 匹配模式

应用字面量的形式创立更加简略,
应用构造函数创立更加灵便 var reg = new RegExp(“a”,”i”);

var reg = /a/i;
console.log(reg.test("abc"));

创立一个正则表达式,查看一个字符串中是否有 a 或 b
应用 | 示意或者的意思

var reg = /a|b/;
console.log(reg.test("acd"));

创立一个正则表达式查看一个字符串是否有字母
[] 里的内容也是或的关系
[ab] == a|b
[a-z] 任意小写字母
[A-Z] 任意大写字母
[A-z] 任意字母
[0-9] 任意数字

reg = /[ab]/
console.log(reg.test("acd"));

查看一个字符串中是否有 abc 或 adc 或 aec

reg = /a[bde]c/
console.log(reg.test("aeec"));      //false
console.log(reg.test("adc"));       //true

[^]除了。除了外面的都行

reg = /[^ab]/;                        // 除了 ab 都行
reg = /[^0-9]/;                        // 除了数字

字符串和正则相干的办法

split()
能够将字符串拆分为一个数组
办法中能够传递一个正则表达式作为参数,这样办法将会依据正则表达式去拆分字符串
这个办法即便不指定全局匹配,也会全都拆分

var str = "1a2b3c4d5e6f"
var result = str.split("c");
console.log(result.length);         //2
console.log(result);                //1a2b3  ,  4d5e6f

依据任意字母来将字符串拆分

var result = str.split(/[A-z]/);
console.log(result);                //1,2,3,4,5,6

search()
能够搜寻字符串中是否含有指定内容
如果搜寻到指定内容,则会返回第一次呈现的索引,如果没有搜寻到返回 -1
它能够承受一个正则表达式作为参数,而后会依据正则表达式去检索字符串
search() 只会查找第一个,即便设置全局匹配也没用 \

str = "hello abc hello abc";
result = str.search("abc");
console.log(result);                //6

搜素字符串中是否还有 abc 或 aec 或 afc

result = str.search(/a[bef]c/);     //6

match()
能够依据正则表达式,从一个字符串中将符合条件的内容提取进去
默认状况下咱们的 match 只会找到第一个符合要求的内容,找到当前就进行检索,
咱们能够设置正则表达式为全局匹配模式,这样就会匹配到所有的内容
咱们为正则表达式设置多个匹配模式,且程序无所谓
match() 会将匹配到的内容封装到一个数组中返回,即便只查问到一个后果

str = "1a2b3c4d5e6f";
result = str.match(/[A-z]/);
console.log(result);                    //a
result = str.match(/[a-z]/ig);            // 即全局又疏忽大小写
console.log(result);                    //a,b,c,d,e,f
console.log(result[1]);                 //b

replace()
能够将字符串中指定内容替换为新的内容
参数:
1. 被替换的内容
2. 新的内容
默认值只会替换第一个,能够承受一个正则表达式作为参数

str = "1a2b3c4d5e6fa8a"
result = str.replace("a","@-@");
console.log(result);                    //1@-@2b3c4d5e6fa8a
result = str.replace(/a/gi,"@-@");        // 即全局又疏忽大小写
console.log(result);                    //1@-@2b3c4d5e6f@-@8@-@
result = str.replace(/[a-z]/gi,"@-@");    // 即全局又疏忽大小写
console.log(result);        

应用空串替换则会都删掉

result = str.replace(/[a-z]/gi,"");
console.log(result);                    //1234568

正则表达式语法

量词
通过量词能够设置一个内容呈现的次数
量词只对它前边的一个内容起作用
{n}: 正好呈现 n 次
{m,n}: 呈现 m 到 n 次
{m,}: 呈现 m 次以上
创立一个正则表达式查看一个字符串中是否还有 aaa

var reg = /a{3}/;                    //aaa
console.log(reg.test("aaabc"))
reg = /(ab){3}/;                    //ababab
reg = /ab{1,3}c/;                    // b 呈现 1 - 3 次
reg = /ab{2,}c/;                    // b 呈现两次以上

+(加号):至多一个,相当于{1,}

reg = /ab+c/;                        // b 至多一个

✳(星号): 0 个或多个,相当于{0,} //b0 或多

reg = /ab*c/;

?(问号): 0 个或 1 个,相当于{0,1} //b0 或 1

reg = /ab?c/;

检察一个字符串中是否以 a 结尾
^: 示意结尾

reg = /^a/;                            // 以 a 结尾

$:示意结尾

reg = /a$/;                            // 以 a 结尾

如果在正则表达式中同时应用 ^$ 则要求字符串必须完全符合正则表达式

reg = /^a$/;                        // a 既是结尾又是结尾
console.log(reg.test("aba"))        //false

以 a 结尾或者以 a 结尾

reg = /^a|a$/;
console.log(reg.test("aba"))        //true

查看一个字符串中是否含有.
. 点 示意任意字符

var reg = /./;
console.log(reg.test("dsadad"));             //true
console.log(reg.test("dsadad..."));         //true

在正则表达式中应用 \ 作为转义字符
. 来示意.

var reg = /\./;
console.log(reg.test("dsadad"));            //false
console.log(reg.test("dsad.ad"));            //true

\ 示意 \

reg = /\\/;
console.log(reg.test("d.\\"));                //true
console.log("\\");                            // 在字符串里 \\ 示意 \,输入一个 \

留神:应用构造函数时因为它的参数是字符串,而 \ 是字符串中转义字符
如果要应用 \ 则须要应用 \ 来代替

reg = new RegExp("\\.");
console.log(reg);                            // 输入 \.
reg = new RegExp("\\\\");    
console.log(reg);                            // 输入 \\

\w
任意字母,数字,_(下划线)[A-z0-9_]

reg = /\w/;
console.log(reg.test("ads54575_"));            //true

\W
除了字母,数字,_(下划线)[^A-z0-9_]

reg = /\W/;
console.log(reg.test("ads54575_"));            //

\d
任意的数字[0-9]

reg = /\d/;
console.log(reg.test("ads_"));                //
console.log(reg.test("574728"));            //

\D
除了数字[^0-9]

reg = /\D/;
console.log(reg.test("ads54575_"));            //
console.log(reg.test("ads_"));                //

\s
空格

reg = /\s/;
console.log(reg.test("ads54575_"));            //
console.log(reg.test("ads5 45 75_"));        //

\S
除了空格

reg = /\S/;
console.log(reg.test("ads54575_"));            //
console.log(reg.test("ads 54 575_"));        //

\b
单词边界(响铃单词空隙)
创立一个正则表达式查看一个字符串中是否含有单词 child

reg = /child/;
console.log(reg.test("children"));        //true 但 child 和 children 不一样
reg = /\bchild\b/;
console.log(reg.test("children"));        //
console.log(reg.test("child hello"));    //

\B
除了单词边界

承受一个用户输出

//var str = prompt("请输出你的用户名");
var str = "h e  l l o"

去除掉字符串中前后的空格

str = str.replace(/\s/g,"")
console.log(str);                        //hello 两头的空格也被去除

去除前边的空格

str = str.replace(/^\s*/,"")
console.log(str);                        //h e  l l o     去前不去后

去除结尾的空格

str = str.replace(/\s*$/,"")
console.log(str);                        //      h e  l l o 去后不去前

匹配结尾结尾的空格去除前后

str = str.replace(/^\s*|\s*$/g,"");
str = str.replace(/^\s+|\s+$/g,"");        // 两种办法区别在于 0 或 1  * 和 + 的规定
console.log(str);                        //h e  l l o 去前后不去两头

邮件的正则

hello@abc.com.cn
任意字母数字下划线. 任意字母数字下划线 @任意字母数字. 任意的字母(2- 5 位). 任意的字母(2- 5 位)
\w{3,}(.\w+)*@[A-z0-9]+([A-z]{2,5}){1,2}

var emailReg = /^\w{3,}(\.\w+)*@[A-z0-9]+(\.[A-z]{2,5}){1,2}$/;
var email = "ada415@ada.com";
console.log(emailReg.test(email));        
正文完
 0