题目1: \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
\d:表示匹配0-9之间的数字
\w:表示匹配单词字符,字母,数字或者字符串
\s:表示空白字符。
[a-zA-Z0-9]表示a-z,A-Z,0-9范围
\b:单词的边界
.:表示除换行符和回车符之外的所有字符
*:零次或者任意多次
+:出现一次或多次
?:出现零次或1次
x{3}:x出现三次
^:出现在[xxx ]表示不是xxx类的任意一类内容。
不出现在[ ]内部的时候表示开头
$:表示出现在尾部
题目2: 写一个函数trim(str),去除字符串两边的空白字符
思路是 字符的前面和后面是空白字符
function trim(str)
{
var str2=str;
var reg=/^\s+\s+&/g;
str2.replace(reg,"");
console.log(str2);
}
trim(" ss ");
image.png
题目3: 写一个函数isEmail(str),判断用户输入的是不是邮箱
思路是 邮箱地址有@,然后@前面是字符串,@后面可以是任意的字符信息。
function isEmail(str)
{
var str2=str;
var reg=/\w+@[a-zA-Z0-9]+(\.[a-zA-Z]+)/g;
return reg.test(str2)
}
isEmail("123@qq.com")
image.png
题目4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号
思路是以1开头,开头的后面有10位的数字,并且以数字结尾,因为如果不以数字结尾,就会出现数字后面是别的字符的情况。所以要限定以数字结尾。
image.png function isPhoneNum(str)
{
var str2=str;
var reg=/^1\d{10}$/g;
return reg.test(str2)
}
题目5: 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
//注意要 开头和结尾的
function isValidUsername(str)
{
var str2=str;
var reg=/^\w{6,20}$/g;
return reg.test(str2)
}
题目6: 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isValidPassword(str)
{
var str2=str;
if(!/^\w{6,20}$/g.test(str2))
{
return false;
}
if(/^[1-9]{6,20}$/g.test(str2))
{return false;}
if(/^[a-z]{6,20}$/g.test(str2))
{return false;}
if(/^[A-Z]{6,20}$/g.test(str2))
{return false;}
if(/^_{6,20}$/g.test(str2))
{return false;}
return true;
}
题目7: 写一个正则表达式,得到如下字符串里所有的颜色
var re =/#([0-9a-fA-F]{6}|[0-9a-fA-F]{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);
8. 下面代码输出什么? 为什么? 改写代码,让其输出['hunger', 'world'].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
结果是:[""hunger" , hello "world""]输出的数组中只有一个字符串,因为*是贪婪模式,会选取在" "中内容最大的。
var str = 'hello "hunger" , hello "world"';
var pat = /".*?"/g;
str.match(pat);
加了?会出现非贪婪模式。
image.png
网友评论