\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^$分别是什么?
- \d : [0-9] 数字字符;
- \w: [a-zA-Z_0-9] 单词字符,字母、数字下划线
- \s: [\t\n\x0B\f\r] 空白符(制表符,换行符,空格,换页符,回车符)
- [a-zA-Z0-9]: 同\w
- \b:匹配单词边界
- . :[^\r\n] 除了回车符和换行符之外的所有字符
- *: 表示匹配0次或任意次
- +表示匹配出现一次或多次(至少出现一次)
- ? 表示匹配零次或一次(最多出现一次)
- x{3} 表示匹配x出现三次以上的元素
- ^$ ^代表行首$代表行尾 ^$意思就是行首之后就是行尾,中间什么也没有
写一个函数trim(str),去除字符串两边的空白字符
function trim(str){
return str.replace(/^\s+str+\s$/g,'')
}
写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
var Regexemail = /^([a-zA-Z_0-9-])+@([a-zA-Z_0-9-])+(\.([a-zA-Z_0-9-]+))$/g;
if(Regexemail.test(str)){
return true ;
}else{
return false;
}
}
写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str){
var phone =/^1(3|4|5|7|8)\d{9}$/;
if(str.match(phone)){
return true;
}else{
return false;
}
}
写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str){
var username = /^\w{6,20}$/;
return username.test(str);
}
写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isValidUsername(str){
if(str.length<6||str.length>20||/\W/.test(str)){
return false;
}
var count = 0;
if(/[0-9]+/.test(str)) count++;
if(/[a-z]+/.test(str)) count++;
if(/[A-Z]+/.test(str)) count++;
if(/[_]+/.test(str)) count++;
if(count>=2){
return true;
}else{
return false;
}
}
写一个正则表达式,得到如下字符串里所有的颜色
var re = /*正则...*/
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
console.log( subj.match(re) )
var re = /#[0-9a-fA-F]{6}/g; //["#121212", "#AA00ef"]
下面代码输出什么? 为什么? 改写代码,让其输出['hunger', 'world'].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat); //输出 [""hunger" , hello "world""] 因为量词在默认下是尽可能多的匹配的,也就
是大家常说的贪婪模式 在量词后加上?即可var pat = /".*?"/g;