http://www.cnblogs.com/rubylouvre/archive/2010/03/09/1681222.html
var reg = /[^0-9]+\w+_$/;
console.log(reg.test('qqq777_'));//true
1、关于\b
\b:匹配一个单词边界,除了空格外,“-”、“/”、“.”、“;”、“,”、“《”等标点符号都被当做单词边界(下划线‘_'不能界定边界),
如'ab_c-d;8<e f.g/h'.replace(/\b(\w)\b/g, '0$1')的结果是:ab_c-0d;08<0e 0f.0g/0h (注意最后一个h也被替换了,因为最开头和最后面默认有一个边界);
又如把2009-8-5转换成2009-08-05,可以‘2009-8-5'.replace(/\b(\d)\b/g, '0$1')=='2009-08-05'
2、关于^和$
这两个分别匹配字符串的开始位置和结束位置。如/4$/表示要以4结尾;/^4$/则只匹配4,像434不匹配。
3、关于匹配汉字
/[\u4e00-\u9fa5]/表示匹配汉字,如把字符串a中所有汉字换成’-‘:a.replace(/[\u4e00-\u9fa5]/g,'-');检验字符串a中是否全是汉字:不是/^[\u4e00-\u9fa5]$/.test(a);这只会匹配一个汉字,应该是/^[\u4e00-\u9fa5]+$/.test(a);
4、关于$1...$9
RegExp对象的$1...$9属性是只读的,如果表达式模式中有括起来的子匹配,$1…$9属性值分别是第1个到第9个子匹配所捕获到的内容。如果有超过9个以上的子匹配,$1…$9属性分别对应最后的9个子匹配。如/^(\d{3,4})-(\d+)$/.test('079-8778');alert(RegExp.$1);alert(RegExp.$2);分别为079和8779.