js下函數(shù)般調(diào)用正則的方法附代碼
更新時間:2008年06月22日 22:00:44 作者:
Firefox 包含了一個非標準的 JavaScript 擴展,使正則像函數(shù)一樣可調(diào)用。這為調(diào)用正則的 exec 方法提供了便捷。例如,在 Firefox中,regex(”string”) 等同于 regex.exec(”string”)。
曾經(jīng) ECMAScript 4 建議指出這個功能將會增加到 ES4 規(guī)范中,但后來的在 ES4-discuss mailing list 的討論中,這個建議可能被廢除。
然而,你可以通過增加 call 和 apply 方法到 RegExp.prototype 中類似的現(xiàn)實這些方法。既有助于功能設計,又可實現(xiàn)對函數(shù)和正則表達式均有效的隱藏類型(duck-typed )代碼。因此,讓我們增加這些方法。
RegExp.prototype.call = function (context, str) {
return this.exec(str);
};
RegExp.prototype.apply = function (context, args) {
return this.exec(args[0]);
};注意上面的兩個方法完全忽略 context 參數(shù),你可以提交 null 或者 任何其他作為 context 的對象,并且你將會類似的得到正則 exec 方法的返回值。使用上面的方法,無論在什么情況下,使我們正常地使用正則表達式和函數(shù)變得容易得多。一些很明顯的例子,比如這些在 JavaScript 1.6 的數(shù)組迭代中很有用。下面的 filter, every, some, 和 map 方法的執(zhí)行可以跨瀏覽器。
if (!Array.prototype.filter) {
// 返回一個數(shù)組,如果提供的過濾函數(shù)返回 true,則返回存在的數(shù)組中的元素。
Array.prototype.filter = function (func, context) {
var results = [];
for (var i = 0; i < this.length; i++) {
if (i in this && func.call(context, this[i], i, this))
results.push(this[i]);
}
return results;
};
}
if (!Array.prototype.every) {
// 返回 true ,如果數(shù)組中的每個元素滿足提供的測試函數(shù)。
Array.prototype.every = function (func, context) {
for (var i = 0; i < this.length; i++) {
if (i in this && !func.call(context, this[i], i, this))
return false;
}
return true;
};
}
if (!Array.prototype.some) {
// 返回 true,如果數(shù)組中至少有一個元素滿足提供的測試函數(shù)。
Array.prototype.some = function (func, context) {
for (var i = 0; i < this.length; i++) {
if (i in this && func.call(context, this[i], i, this))
return true;
}
return false;
};
}
if (!Array.prototype.map) {
// 返回一個數(shù)組,現(xiàn)有數(shù)組中的每個元素調(diào)用提供的函數(shù)的返回值。
Array.prototype.map = function (func, context) {
var results = [];
for (var i = 0; i < this.length; i++) {
if (i in this)
results[i] = func.call(context, this[i], i, this);
}
return results;
};
}因為exec 方法返回數(shù)組或 null 值,并會恰當?shù)念愋娃D換為 true 和 false,上面的代碼允許我們像這樣使用:["a","b","ab","ba"].filter(/^a/),返回所有以“a”開始的值:["a","ab"]。
確實,在 Firefox 中已經(jīng)實現(xiàn)了 Array.prototype.filter ,由于 exec 的間接調(diào)用已經(jīng)在該瀏覽器中起作用了。但是如果 filter 沒有添加 RegExp.prototype.call 方法,卻無法跨瀏覽器執(zhí)行。
然而,你可以通過增加 call 和 apply 方法到 RegExp.prototype 中類似的現(xiàn)實這些方法。既有助于功能設計,又可實現(xiàn)對函數(shù)和正則表達式均有效的隱藏類型(duck-typed )代碼。因此,讓我們增加這些方法。
RegExp.prototype.call = function (context, str) {
return this.exec(str);
};
RegExp.prototype.apply = function (context, args) {
return this.exec(args[0]);
};注意上面的兩個方法完全忽略 context 參數(shù),你可以提交 null 或者 任何其他作為 context 的對象,并且你將會類似的得到正則 exec 方法的返回值。使用上面的方法,無論在什么情況下,使我們正常地使用正則表達式和函數(shù)變得容易得多。一些很明顯的例子,比如這些在 JavaScript 1.6 的數(shù)組迭代中很有用。下面的 filter, every, some, 和 map 方法的執(zhí)行可以跨瀏覽器。
if (!Array.prototype.filter) {
// 返回一個數(shù)組,如果提供的過濾函數(shù)返回 true,則返回存在的數(shù)組中的元素。
Array.prototype.filter = function (func, context) {
var results = [];
for (var i = 0; i < this.length; i++) {
if (i in this && func.call(context, this[i], i, this))
results.push(this[i]);
}
return results;
};
}
if (!Array.prototype.every) {
// 返回 true ,如果數(shù)組中的每個元素滿足提供的測試函數(shù)。
Array.prototype.every = function (func, context) {
for (var i = 0; i < this.length; i++) {
if (i in this && !func.call(context, this[i], i, this))
return false;
}
return true;
};
}
if (!Array.prototype.some) {
// 返回 true,如果數(shù)組中至少有一個元素滿足提供的測試函數(shù)。
Array.prototype.some = function (func, context) {
for (var i = 0; i < this.length; i++) {
if (i in this && func.call(context, this[i], i, this))
return true;
}
return false;
};
}
if (!Array.prototype.map) {
// 返回一個數(shù)組,現(xiàn)有數(shù)組中的每個元素調(diào)用提供的函數(shù)的返回值。
Array.prototype.map = function (func, context) {
var results = [];
for (var i = 0; i < this.length; i++) {
if (i in this)
results[i] = func.call(context, this[i], i, this);
}
return results;
};
}因為exec 方法返回數(shù)組或 null 值,并會恰當?shù)念愋娃D換為 true 和 false,上面的代碼允許我們像這樣使用:["a","b","ab","ba"].filter(/^a/),返回所有以“a”開始的值:["a","ab"]。
確實,在 Firefox 中已經(jīng)實現(xiàn)了 Array.prototype.filter ,由于 exec 的間接調(diào)用已經(jīng)在該瀏覽器中起作用了。但是如果 filter 沒有添加 RegExp.prototype.call 方法,卻無法跨瀏覽器執(zhí)行。
相關文章
Linux服務器配置PHP文件下載,中文亂碼問題,下載出錯如何解決
這篇文章主要介紹了Linux服務器配置PHP文件下載,中文亂碼問題,下載出錯如何解決,感興趣的小伙伴可以看下2021-07-07基于 GPT-4 編寫、解釋代碼的新一代編輯器 Cursor
這篇文章主要介紹了基于 GPT-4 編寫、解釋代碼的新一代編輯器 Cursor的相關資料,需要的朋友可以參考下2023-03-03eval(cmd)與eval($cmd)的區(qū)別與聯(lián)系
這篇文章主要介紹了eval(cmd)與eval($cmd)的區(qū)別與聯(lián)系,希望對屏幕前的你有所幫助2021-07-07