正则表达式

题目1: \d,\w,\s,[a-zA-Z0-9],\b,.,*,+,?,x{3},^,$分别是什么?

        \d : 数字字符
        \w : 单词字符,字母、数字下划线
        \s : 空白符
[a-zA-Z0-9] :  字母a到z(包含大小写),数字0到9
        \b : 单词边界
         . :  除了换行和回车之外的任意字符
         * :  出现零次或多次(任意次)
         + :  出现一次或多次(至少一次)
         ? :  出现零次或一次
      x{3} :  对应零次或者3次
         ^ :  开头
         $ :  结尾

题目2: 写一个函数trim(str),去除字符串两边的空白字符

function trim(str) {
    return str.replace(/^\s+|\s+$/g, '');
}
str = "     aa bb cc      ";
trim(str);

题目3: 写一个函数isEmail(str),判断用户输入的是不是邮箱

function isEmai(str) {
    return  /^(\w+)(\.\w+)*@(\w+)((\.\w+)+)$/.test(str);
}
str = "[email protected]";
isEmai(str);

题目4: 写一个函数isPhoneNum(str),判断用户输入的是不是手机号

function isPhoneNum(str) {
    return /^(\+86)?1(3|4|5|7|8)[0-9]\d{8}$/.test(str);
}

题目5: 写一个函数isValidUsername(str),判断用户输入的是不是合法的用户名(长度6-20个字符,只能包括字母、数字、下划线)

function isValidUsername(str) {
    return /^\w{6,20}$/.test(str);
}

题目6: 写一个函数isValidPassword(str), 判断用户输入的是不是合法密码(长度6-20个字符,只包括大写字母、小写字母、数字、下划线,且至少至少包括两种)

function isVaildPassword(str) {
    if(str.length < 6 || str.length >20) return false;
    if(/^[A-Z]+$/.test(str)) return false;
    if(/^[a-z]+$/.test(str)) return false;
    if(/^\d+$/.test(str)) return false;
    if(/^_+$/.test(str)) return false;
    return true;
}

题目7: 写一个正则表达式,得到如下字符串里所有的颜色

var re = /#[a-f0-9]{6}/gi
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""]

当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提下)匹配尽可能多的字符。以这个表达式为例:a.b,它将会匹配最长的以a开始,以b结束的字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。
有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒惰匹配模式,只要在它后面加上一个问号?。这样.
?就意味着匹配任意数量的重复,但是在能使整个匹配成功的前提下使用最少的重复。现在看看懒惰版的例子吧:
a.*?b匹配最短的,以a开始,以b结束的字符串。如果把它应用于aabab的话,它会匹配aab(第一到第三个字符)和ab(第四到第五个字符)。

var str = 'hello  "hunger" , hello "world"';
var pat =  /".*?"/g;
str.match(pat);     // 加一个问号? 转化成懒惰模式,尽量匹配少的字符

你可能感兴趣的:(正则表达式)