首页前端开发其他前端知识正则匹配的test函数

正则匹配的test函数

时间2024-02-01 14:39:03发布访客分类其他前端知识浏览572
导读:收集整理的这篇文章主要介绍了正则匹配的test函数,觉得挺不错的,现在分享给大家,也给大家做个参考。 VAR fntest = /xyz/.test(function( {xyz;} ...
收集整理的这篇文章主要介绍了正则匹配的test函数,觉得挺不错的,现在分享给大家,也给大家做个参考。 VAR fntest = /xyz/.test(function(){ xyz; } ) ? /b_suPErb/ : /.*/; 对于其中正则表达式匹配函数test的用法,我很是迷惑:
/xyz/.test(function(){ xyz; } )我查阅了Mozilla developer center中关于test函数的描述:
Executes the seArch for a match between a regular exPression and a specified string. Returns true or false.
字符串中是否有匹配正则表达式的子字符串。返回true或false。
其语法格式:
regexp.test([str])注意这里的参数是字符串,根本没有提到test函数的参数可以是函数的说法。
我试着修改这段奇怪的代码,得到了一些运行结果:
复制代码 代码如下:
/xyz/.test("xyz"); // true
/xyz/.test(function(){ "xyz"; } ); // false
/xyz/.test(function(){ return "xyz"; } ); // true
/xyz/.test(function(){ return xyz; } ); // true
/xyz/.test(function(){ return axyz; } ); // true
/xyz/.test(function(){ return "axyz"; } ); // true
/xyz/.test(function(){ return "xayz"; } ); // false怎么回事?

华丽的分割线
=======================================
我终于知道了,却原来在test内部进行了类型转换,下面代码:
复制代码 代码如下:
/xyz/.test(function(){ xyz; } );

等价于:
复制代码 代码如下:
/xyz/.test((function(){ xyz; } ).toString());

又等价于:
复制代码 代码如下:
/xyz/.test("function(){ xyz; } ");

那么为什么下面的代码返回false呢?
复制代码 代码如下:
/xyz/.test(function(){ "xyz"; } );

我们执行下这行代码就知道了:
复制代码 代码如下:
// 这行代码的执行结果是:"function(){ } "
(function(){ "xyz"; } ).toString();

所以我们可以写出更加诡异的代码来迷惑大家了
复制代码 代码如下:
/function/.test(function(){ } ); // true
// b 表示文字边界(对英文而言的)
/b_superb/.test(function(){ this._super(); } ); // true

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

正则

若转载请注明出处: 正则匹配的test函数
本文地址: https://pptw.com/jishu/595531.html
javascript 正则表达式用法 小结 JavaScript 正则表达式 验证整数、小数、实数、有效位小数最简单

游客 回复需填写必要信息