javascript正则表达式学习之位置匹配(2)
2020-09-03 15:45saucxs 正则表达式
4 3.3 (?=p) 和 (?!p) (?=p)其中p是一个子模式,即 p前面的位置 (该位置后面的字符要匹配p) 比如:(?=e),表示的是e字符前面的位置; ? 1 2 3 var result = hello .r
3.3 (?=p) 和 (?!p)
(?=p)其中p是一个子模式,即 p前面的位置 (该位置后面的字符要匹配p)
比如:(?=e),表示的是e字符前面的位置;
1
2
3
|
var result = "hello" .replace(/(?=l)/g, '#' ); console.log(result); // "he#l#lo" |
而(?!p)就是(?=p)的反面意思
1
2
3
|
var result = "hello" .replace(/(?!l)/g, '#' ); console.log(result); // "#h#ell#o#" |
二者的学名分别是 positive lookahead
和 negative lookahead。
中文翻译分别是 正向先行断言 和 负向先行断言 。
ES5 之后的版本,会支持 positive lookbehind 和 negative lookbehind。
具体是 (?<=p) 和 (?<!p)。
四、位置特性
对于位置的理解,我们可以累计额成空字符""。
比如"hello"字符串等价于如下形式:
1
|
"hello" == "" + "h" + "" + "e" + "" + "l" + "" + "l" + "" + "o" + "" ; |
也等价于
1
|
"hello" == "" + "" + "hello" |
因此,把 /^hello$/ 写成 /^^hello$$$/,是没有任何问题的:
1
2
3
|
var result = /^^hello$$$/.test( "hello" ); console.log(result); // true |
也就是说,字符之间的位置,可以写成多个。
注:把 位置 理解 空字符 ,是对位置非常有效的理解方式
五、相关案例
5.1不匹配任何东西的正则
/.^/
正则要求 只有一个字符,但是该字符后面是开头 ,而这样的字符串是不存在的。
5.2数字的千分位分隔符表示法
比如吧12345678,变成12,345,678。
分析:那就是需要把相应的位置替换成","
5.2.1弄出来最后一个逗号
正则:/(?=\d{3}$)/
1
2
|
var result = "12345678" .replace(/(?=\d{3}$)/g, ',' )console.log(result); // 12345,678 |
其中(?=\d{3}$)匹配\d{3}$前面的位置。而\d{3}$匹配的是目标字符串最后那3为数字。
5.2.2弄出来多有逗号
因为逗号的出现的位置,要求后边3个数字一组,也就是\d{3}至少出现1次。
可以使用量词 + :
1
2
|
var result = "12345678" .replace(/(?=(\d{3})+$)/g, ',' )console.log(result); // 12,345,678 |
5.2.3匹配其余案例
写完正则后,是需要举个别案例来验证的,就会发现问题:
1
2
|
var result = "123456789" .replace(/(?=(\d{3})+$)/g, ',' )console.log(result); // ,123,456,789 |
上面的正则,仅仅是表示把从结尾向前数,一旦是3的倍数买酒吧前面的位置替换为逗号。
还需要要求:匹配的这个位置不能是开头。
我们知道开头的匹配是使用^,但是不是开头怎么整?
使用(?!^)
1
2
3
|
var regex = /(?!^)(?=(\d{3})+$)/g; var result = "12345678" .replace(regex, ',' )console.log(result); // "12,345,678"result = "123456789".replace(regex, ','); console.log(result); // "123,456,789" |
5.2.4支持其他形式
如果要把 "12345678 123456789" 替换成 "12,345,678 123,456,789"。
此时我们需要修改正则,把里面的开头 ^ 和结尾 $,修改成 \b:
1
2
3
|
var string = "12345678 123456789" ,regex = /(?!\b)(?=(\d{3})+\b)/g; var result = string.replace(regex, ',' )console.log(result); // "12,345,678 123,456,789" |
其中(?!\b)怎么理解?
要求是当前的一个位置,但不是\b前面的位置,其实(?!\b)说的是\B。
因此最终正则变成了:/\B(?=(\d{3})+\b)/g。
可视化形式:
RegExp:/\B(?=(\d{3})+\b)/g
5.2.5货币格式化
千分符表示法一个常见的应用就是货币格式化。
把这个字符串:
格式化:
$ 1888.00
实现:
1
2
3
4
|
function format (num) { return num.toFixed(2).replace(/\B(?=(\d{3})+\b)/g, "," ).replace(/^/, "$ " ); }; console.log( format(1888) ); // "$ 1,888.00" |
5.3验证密码的问题
密码长度6-12,由数字,小写字母,大写字母组成,但必须至少包括2种字符。
写成多个正则来判断,比较容易,但是要写成一个正则就比较困难。
来看看我们对于位置的理解是否深刻。
5.3.1简化
暂时不考虑"必须至少包含2种字符"这个条件,可以容易写出:
1
|
var regex = /^[0-9A-Za-z]{6,12}$/; |
5.3.2判断是否包含有某一种字符
假设,要求我们必须包含数字,怎么整?此时我们可以使用(?=.*[0-9])来实现。
正则变成:
1
|
var regex = /(?=.*[0-9])^[0-9A-Za-z]{6,12}$/; |
5.3.3同时包含具体两种字符
比如同时包含数字和小写字母,可以使用(?=.*[0-9])(?=.*[a-z])来实现。
正则变成:
1
|
var regex = /(?=.*[0-9])(?=.*[a-z])^[0-9A-Za-z]{6,12}$/; |
5.3.3具体实现
把原题变成下列几种情况:
1、同时包含数字和小写字母;
2、同时包含数字和大写字母;
3、同时包含小写字母和大写字母;
4、同时包含数字,小写字母和大写字母。
以上的4中情况是 或 的关系(实际上,第四条可以不用)。
最终答案:
1
2
3
4
5
6
7
|
var regex = /((?=.*[0-9])(?=.*[a-z])|(?=.*[0-9])(?=.*[A-Z])|(?=.*[a-z])(?=.*[AZ]))^[0-9A-Za-z]{6,12}$/;console.log( regex.test( "1234567" ) ); // false 全是数字console.log( regex.test("abcdef") ); // false 全是小写字母console.log( regex.test("ABCDEFGH") ); // false 全是大写字母console.log( regex.test("ab23C") ); // false 不足6位console.log( regex.test("ABCDEF234") ); // true 大写字母和数字console.log( regex.test("abcdEF234") ); // true 三者都有 |
可视化形式:
RegExp:/((?=.*[0-9])(?=.*[a-z])|(?=.*[0-9])(?=.*[A-Z])|(?=.*[a-z])(?=.*[AZ]))^[ 0-9A-Za-z]{6,12}$/
分析:
上面正则看起来好复杂,只需要理解第二步,/(?=.*[0-9])^[0-9A-Za-z]{6,12}$/;
对于这个正则,我们需要明白(?=.*[0-9])^这个;
分开来看就是(?=.*[0-9]) 和 ^。
表示开头前面还有个位置(当然也是开头,即同一个位置,想想之前的空字符类比)。
(?=.*[0-9]) 表示该位置后面的字符匹配。
.*[0-9],即,有任何多个任意字符,后面再跟个数字。
翻译成大白话,就是接下来的字符,必须包含个数字。
5.3.4另外一种解法
“至少包含两种字符”的意思就是说,不能全部都是数字,也不能全部都是小写字母,也不能全部都是大写字母。
那么要求“不能全部都是数字”,怎么做呢? (?!p) 出马!
对应的正则:
1
|
var regex = /(?!^[0-9]{6,12}$)^[0-9A-Za-z]{6,12}$/; |
三种“都不能”呢?
最终答案是:
1
2
3
4
5
6
7
8
|
var regex = /(?!^[0-9]{6,12}$)(?!^[a-z]{6,12}$)(?!^[A-Z]{6,12}$)^[0-9A-Za-z]{6,12}$/; console.log( regex.test( "1234567" ) ); // false 全是数字console.log( regex.test("abcdef") ); // false 全是小写字母console.log( regex.test("ABCDEFGH") ); // false 全是大写字母console.log( regex.test("ab23C") ); // false 不足6位console.log( regex.test("ABCDEF234") ); // true 大写字母和数字console.log( regex.test("abcdEF234") ); // true 三者都有 |
可视化形式:
RegExp:/(?!^[0-9]{6,12}$)(?!^[a-z]{6,12}$)(?!^[A-Z]{6,12}$)^[0-9A-Za-z]{6,12}$/;
总结
以上所述是小编给大家介绍的javascript正则表达式学习之位置匹配,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:http://www.cnblogs.com/chengxs/p/10714851.html
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
UBB代码是HTML的一个变种。一般情况下,UBB论坛不允许你使用HTML代码,而只能用UBB代码替代HTML代码。...
正则表达式(Regular Expression)是一个概念,一种语法、句法的约定。每一种具体的语句(C#,Java,JavaScript)有其对于正则表达式的具体实现,并且会有差别。...
我使用DW 这个所见所得的编辑器来写html时,喜欢写上注释,如 等等的注释,在一次比较大的改动时,需要批量查找替换,为了批量操作,于是...
最近在开发过程中,需要一个输入框里面只能有数字与中英文逗号,因为是相关文章,其它的也不让出现,容易造成问题,编程容易把介绍复制到里面,所...
上篇文章《JavaScript验证正则表达式大全》说的是javascript中使用的正则表达式的例子,但是没有说这些正则表达式如何使用,现在给大家几个例子,大家可...
这篇文章主要介绍了php与javascript正则匹配中文的方法,结合实例形式分析了针对utf-8与GBK编码情况下的php、javascript正则匹配中文操作技巧,需要的朋友可以参...
PHP正则校验email的代码相信好好学过PHP的人都应该知道下面这段用于eamil校验的语句,但是真正能看懂的就不多了。...
PHP匹配多行的正则表达式分析,需要的朋友可以参考下,多用于采集替换等。...