正則匹配的test函數(shù)
更新時(shí)間:2009年07月13日 22:36:11 作者:
在John Resig 那篇關(guān)于在JavaScript中實(shí)現(xiàn)簡(jiǎn)單繼承的文章中,有這樣一段代碼
var fnTest = /xyz/.test(function(){xyz;}) ? /b_superb/ : /.*/;對(duì)于其中正則表達(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。
其語(yǔ)法格式:
regexp.test([str])注意這里的參數(shù)是字符串,根本沒(méi)有提到test函數(shù)的參數(shù)可以是函數(shù)的說(shuō)法。
我試著修改這段奇怪的代碼,得到了一些運(yùn)行結(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怎么回事?
華麗的分割線
=======================================
我終于知道了,卻原來(lái)在test內(nèi)部進(jìn)行了類型轉(zhuǎn)換,下面代碼:
/xyz/.test(function(){xyz;});
等價(jià)于:
/xyz/.test((function(){xyz;}).toString());
又等價(jià)于:
/xyz/.test("function(){xyz;}");
那么為什么下面的代碼返回false呢?
/xyz/.test(function(){"xyz";});
我們執(zhí)行下這行代碼就知道了:
// 這行代碼的執(zhí)行結(jié)果是:"function(){}"
(function(){"xyz";}).toString();
所以我們可以寫(xiě)出更加詭異的代碼來(lái)迷惑大家了
/function/.test(function(){}); // true
// b 表示文字邊界(對(duì)英文而言的)
/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。
其語(yǔ)法格式:
regexp.test([str])注意這里的參數(shù)是字符串,根本沒(méi)有提到test函數(shù)的參數(shù)可以是函數(shù)的說(shuō)法。
我試著修改這段奇怪的代碼,得到了一些運(yùn)行結(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怎么回事?
華麗的分割線
=======================================
我終于知道了,卻原來(lái)在test內(nèi)部進(jìn)行了類型轉(zhuǎn)換,下面代碼:
復(fù)制代碼 代碼如下:
/xyz/.test(function(){xyz;});
等價(jià)于:
復(fù)制代碼 代碼如下:
/xyz/.test((function(){xyz;}).toString());
又等價(jià)于:
復(fù)制代碼 代碼如下:
/xyz/.test("function(){xyz;}");
那么為什么下面的代碼返回false呢?
復(fù)制代碼 代碼如下:
/xyz/.test(function(){"xyz";});
我們執(zhí)行下這行代碼就知道了:
復(fù)制代碼 代碼如下:
// 這行代碼的執(zhí)行結(jié)果是:"function(){}"
(function(){"xyz";}).toString();
所以我們可以寫(xiě)出更加詭異的代碼來(lái)迷惑大家了
復(fù)制代碼 代碼如下:
/function/.test(function(){}); // true
// b 表示文字邊界(對(duì)英文而言的)
/b_superb/.test(function(){this._super();}); // true
相關(guān)文章
在nest.js中通過(guò)正則表達(dá)式正確設(shè)置驗(yàn)證的方法
這篇文章主要介紹了在nest.js中通過(guò)正則表達(dá)式正確設(shè)置驗(yàn)證的方法,文末給大家補(bǔ)充介紹了js正則表達(dá)式驗(yàn)證大全,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒借鑒價(jià)值,需要的朋友可以參考下2022-03-03詳解正則表達(dá)式之?dāng)?shù)字驗(yàn)證
這篇文章將介紹一些常用的數(shù)字驗(yàn)證方法,包括整數(shù)驗(yàn)證、國(guó)內(nèi)電話號(hào)碼驗(yàn)證、身份證號(hào)碼驗(yàn)證、以及IP地址驗(yàn)證等等驗(yàn)證方法,有興趣的可以了解一下。2016-12-12