1: \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
\d:可以匹配任何一个 0~9 数字字符。
\w:可以匹配任何一个字母或者数字或者下划线。
\s:可以匹配空格、制表符、换页符等空白字符的其中任意一个。
[a-zA-Z0-9]:
可以匹配0-9,a-z,A-Z中的任意一个。
\b:匹配字符串的开始或结束位置,\b并不匹配单词分隔字(空格,标点符号或者换行)中的任何一个,它只匹配一个位置。
.:小数点可以匹配除了换行符(\n)以外的任意一个字符。
+:表达式尽可能的多匹配,至少匹配1次,相当于 {1, }。
?:尽可能匹配1次,也可以不匹配,相当于 {0, 1}。
x{3}:表达式固定重复3次,如:"x{3}" 相当于 "xxx"。
:如果写在中括号外如:[],匹配输入字符串开始的位置,如果写在中括号内,如[a-z]表示反向范围字符。匹配不在指定的范围内的任何字符,“[a-z]”匹配任何不在“a”到“z”范围内的任何字符。
$:匹配输入字符串结尾的位置。
2: 写一个函数trim(str),去除字符串两边的空白字符
function trim(str){
return str.replace(/^\s+|\s+$/g,'');
}
var str=' ha sh sh sj sj jj js js ';
console.log(str.length);//38
console.log(trim(str).length);//30、
3: 写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str){
var reg= /^(\w)+@(\w)+(\.\w+)$/;
return reg.test(str);
}
var email="544@233.com";
console.log(isEmail(email));//true
4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str){
var reg=/^1[35678]\d{9}$/;
return reg.test(str);
}
var a='13111111111';
console.log(isPhoneNum(a));//true
5: 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str){
var reg=/^\w{6,20}$/;
return reg.test(str);
}
var b='_weeewewe_111';
console.log(isValidUsername(b));//true
6: 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
1.
function isValidPassword(str){
if(str.length<6||str.length>20||/\W/.test(str)){
return '请输入正确的密码';
}
var reg=/((?=.*\d)(?=.*\D)|(?=.*[a-zA-Z])(?=.*[^a-zA-Z]))^.{6,20}$/;
return reg.test(str);
}
var s='1AAA22';
console.log(isValidPassword(s));//true
2.
function isValidPassword(str){
if(str.length<6||str.length>20||/\W/.test(str))
return '请输入正确的密码';
var count=0;
if(str.length>6&&str.length<20)count++;
if((/[A-Z]/).test(str))count++;
if((/[a-z]/).test(str))count++;
if((/[0-9]/).test(str))count++;
if((/_/).test(str))count++;
if(count>=2){
return true;
}else {
return '请输入正确的密码';
}
}
var s='1AAA';
console.log(isValidPassword(s));//false
7: 写一个正则表达式,得到如下字符串里所有的颜色
var re = /#([A-Fa-f0-9]{6})|([A-Fa-f0-9]{3})$/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;
str.match(pat);//[""hunger" , hello "world""],因为“.”匹配除了换行符(\n)以外的任意一个字符,又*前一个表达式0次或多次,在非贪婪模式的条件下,会尽可能的匹配更多符合的字符,“hunger”, "hello","world"都符合。
让其输出[""hunger"", ""world""]
var pat = /".*?"/g;
console.log(str.match(pat));//[""hunger"", ""world""]