正則匹配的test函數(shù)
更新時間:2009年07月13日 22:36:11 作者:
在John Resig 那篇關(guān)于在JavaScript中實現(xiàn)簡單繼承的文章中,有這樣一段代碼
var fnTest = /xyz/.test(function(){xyz;}) ? /b_superb/ : /.*/;對于其中正則表達(dá)式匹配函數(shù)test的用法,我很是迷惑:
/xyz/.test(function(){xyz;})我查閱了Mozilla developer center中關(guān)于test函數(shù)的描述:
Executes the search for a match between a regular expression and a specified string. Returns true or false.
字符串中是否有匹配正則表達(dá)式的子字符串。返回true或false。
其語法格式:
regexp.test([str])注意這里的參數(shù)是字符串,根本沒有提到test函數(shù)的參數(shù)可以是函數(shù)的說法。
我試著修改這段奇怪的代碼,得到了一些運行結(jié)果:
/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內(nèi)部進行了類型轉(zhuǎn)換,下面代碼:
/xyz/.test(function(){xyz;});
等價于:
/xyz/.test((function(){xyz;}).toString());
又等價于:
/xyz/.test("function(){xyz;}");
那么為什么下面的代碼返回false呢?
/xyz/.test(function(){"xyz";});
我們執(zhí)行下這行代碼就知道了:
// 這行代碼的執(zhí)行結(jié)果是:"function(){}"
(function(){"xyz";}).toString();
所以我們可以寫出更加詭異的代碼來迷惑大家了
/function/.test(function(){}); // true
// b 表示文字邊界(對英文而言的)
/b_superb/.test(function(){this._super();}); // true
/xyz/.test(function(){xyz;})我查閱了Mozilla developer center中關(guān)于test函數(shù)的描述:
Executes the search for a match between a regular expression and a specified string. Returns true or false.
字符串中是否有匹配正則表達(dá)式的子字符串。返回true或false。
其語法格式:
regexp.test([str])注意這里的參數(shù)是字符串,根本沒有提到test函數(shù)的參數(shù)可以是函數(shù)的說法。
我試著修改這段奇怪的代碼,得到了一些運行結(jié)果:
復(fù)制代碼 代碼如下:
/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內(nèi)部進行了類型轉(zhuǎn)換,下面代碼:
復(fù)制代碼 代碼如下:
/xyz/.test(function(){xyz;});
等價于:
復(fù)制代碼 代碼如下:
/xyz/.test((function(){xyz;}).toString());
又等價于:
復(fù)制代碼 代碼如下:
/xyz/.test("function(){xyz;}");
那么為什么下面的代碼返回false呢?
復(fù)制代碼 代碼如下:
/xyz/.test(function(){"xyz";});
我們執(zhí)行下這行代碼就知道了:
復(fù)制代碼 代碼如下:
// 這行代碼的執(zhí)行結(jié)果是:"function(){}"
(function(){"xyz";}).toString();
所以我們可以寫出更加詭異的代碼來迷惑大家了
復(fù)制代碼 代碼如下:
/function/.test(function(){}); // true
// b 表示文字邊界(對英文而言的)
/b_superb/.test(function(){this._super();}); // true
相關(guān)文章
在nest.js中通過正則表達(dá)式正確設(shè)置驗證的方法
這篇文章主要介紹了在nest.js中通過正則表達(dá)式正確設(shè)置驗證的方法,文末給大家補充介紹了js正則表達(dá)式驗證大全,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒借鑒價值,需要的朋友可以參考下2022-03-03