1.\d, \w, \s, [a-zA-Z0-9], \b, ., *, +, ? ,x{3}, ^, $分别是什么?
字符 | 含义 |
---|---|
\d | 数字字符;等价[0-9] |
\w | 单词字符,字母、数字下划线;等价[a-zA-Z_0-9] |
\s | 空白符 |
[a-zA-Z0-9] | 包括数字、小写字母、大写字母 |
\b | 单词边界 |
. | 除了回车符和换行符之外的所有字符 |
* | 出现零次或多次(任意次) |
+ | 出现一次或多次(至少出现一次) |
? | 出现零次或一次(最多出现一次) |
x{3} | x出现3次 |
^ | 以xxx开头 |
$ | 以xxx结尾 |
2.写一个函数trim(str),去除字符串两边的空白字符。
function trim(str){ return str.replace(/^\s+|\s+$/g, ''); }; var str2=" jirengu "; console.log(trim(str2)); //jirengu
3.写一个函数isEmail(str),判断用户输入的是不是邮箱。
function isEmail(str){ return /^\w+@[\w+.]+$/.test(str); };
4.写一个函数isPhoneNum(str),判断用户输入的是不是手机号。
function isPhoneNum (str){ return /^(\+86-)?1[3568]{1}[0-9]{9}$/.test(str); }
5.写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)。
function isValidUsername (str){ return /^\w{6,20}$/.test(str); }
6.写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)。
function isValidPassword (str){ if(/^\w{6,20}$/.test(str)){ var num = 0; if(/[A-Z]/.test(str)) { num++; } if(/[a-z]/.test(str)){ num++; } if(/[0-9]/.test(str)){ num++; } if(/_/.test(str)){ num++; } if(num>=2){ return true; } } return false; } ;
7.写一个正则表达式,得到如下字符串里所有的颜色。
var re = /#[a-zA-Z0-9]{6}/g; var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee " console.log( subj.match(re) ) // ['#121212', '#AA00ef']
8.下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""]。
`var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
console.log(str.match(pat));
//输出[""hunger" , hello "world""],原因是,匹配除换行符和回车符外的任意单个字符,而量词默认为是贪婪模式,在满足条件的情况下,会尽可能多的匹配。
var req = /".*?"/g;
console.log(str.match(req)); //设置成非贪婪模式,即可输出[""hunger"", ""world""]。
`