\d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?
-
\d
代表数字字符,等同于[0-9]
-
\w
代表单词字符,字母、数字及下划线,等同于[0-9a-zA-Z_]
-
\s
代表空白符,等同于[\t\n\x0B\f\r]
-
[a-zA-Z0-9]
代表所有大小写字母及数字,即'abcdefg...xyzABCDEFG...XYZ0123456789'
-
\b
代表单词的边界
-
.
代表除了回车符和换行符之外的所有字符
-
*
出现零次或多次(任意次)
-
+
出现一次或多次(至少出现一次)
-
?
出现零次或一次(最多出现一次)
-
x{3}
字符x
重复3次
-
^
以某个字符开头
-
$
以某个字符结尾
写一个函数trim(str),去除字符串两边的空白字符
function trim(str) {
return str.replace(/^\s+ | \s+$/g, '');
}
写一个函数isEmail(str),判断用户输入的是不是邮箱
function isEmail(str) {
var reg = /^\w+@\w+\.[a-z]+$/;
return reg.test(str);
}
写一个函数isPhoneNum(str),判断用户输入的是不是手机号
function isPhoneNum(str) {
var reg = /^1[3578]\d{9}$/;
return reg.test(str);
}
写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)
function isValidUsername(str) {
var reg = /\w{6,20}/;
return reg.test(str);
}
写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)
function isValidPassword(str) {
if(!/^\w{6,20}$/.test(str)) return false;
if(/^[a-z]{6,20}$/.test(str)) return false;
if(/^[A-Z]{6,20}$/.test(str)) return false;
if(/^\d{6,20}$/.test(str)) return false;
if(/^_{6,20}$/.test(str)) return false;
else return true;
}
写一个正则表达式,得到如下字符串里所有的颜色
var re = /#([0-9a-fA-F]{6}|[0-9a-fA-F]{3})\b/g;
var subj = "color: #121212; background-color: #AA00ef; width: 12px; bad-colors: f#fddee "
console.log( subj.match(re) ) // ['#121212', '#AA00ef']
下面代码输出什么? 为什么? 改写代码,让其输出[""hunger"", ""world""].
var str = 'hello "hunger" , hello "world"';
var pat = /".*"/g;
str.match(pat);
/* 代码输出的是[""hunger" , hello "world""],
因为 . 匹配的是除了换行和回车外的所有字符,而 * 的意思是重复零次或多次,
所以这个正则表达式的 .* 会将字符串"hunger" , hello "world"中hunger右边的双引号、world左边的双引号、逗号、空格都匹配,
而正则表达式里的标记开始和结束的双引号只能匹配到hunger左边的和world右边的,所以输出结果是[""hunger" , hello "world""]。 */
// 改写
var str = 'hello "hunger" , hello "world"';
var pat = /"\w*"/g;
str.match(pat);
// 或
var str = 'hello "hunger" , hello "world"';
var pat = /"[^"\s]*"/g;
str.match(pat);