js函数般调用正则
js函数般调用正则
发布时间:2016-12-30 来源:查字典编辑
摘要:这为调用正则的exec方法提供了便捷。例如,在Firefox中,regex(”string”)等同于regex.exec(”string”)...

这为调用正则的 exec 方法提供了便捷。例如,在 Firefox中,regex(”string”) 等同于 regex.exec(”string”)。曾经 ECMAScript 4 建议指出这个功能将会增加到 ES4 规范中,但后来的在 ES4-discuss mailing list 的讨论中,这个建议可能被废除。

然而,你可以通过增加 call 和 apply 方法到 RegExp.prototype 中类似的现实这些方法。既有助于功能设计,又可实现对函数和正则表达式均有效的隐藏类型(duck-typed )代码。因此,让我们增加这些方法。

复制代码 代码如下:

RegExp.prototype.call=function(context,str){

returnthis.exec(str);

};

RegExp.prototype.apply=function(context,args){

returnthis.exec(args[0]);

};

注意上面的两个方法完全忽略 context 参数,你可以提交 null 或者 任何其他作为 context 的对象,并且你将会类似的得到正则 exec 方法的返回值。使用上面的方法,无论在什么情况下,使我们正常地使用正则表达式和函数变得容易得多。一些很明显的例子,比如这些在 JavaScript 1.6 的数组迭代中很有用。下面的 filter, every, some, 和 map 方法的执行可以跨浏览器。

复制代码 代码如下:

varresults=[];

for(vari=0;i<this.length;i++){

if(iinthis&&func.call(context,this[i],i,this))

results.push(this[i]);

}

returnresults;

};

}

if(!Array.prototype.every){

//返回true,如果数组中的每个元素满足提供的测试函数。

Array.prototype.every=function(func,context){

for(vari=0;i<this.length;i++){

if(iinthis&&!func.call(context,this[i],i,this))

returnfalse;

}

returntrue;

};

}

if(!Array.prototype.some){

//返回true,如果数组中至少有一个元素满足提供的测试函数。

Array.prototype.some=function(func,context){

for(vari=0;i<this.length;i++){

if(iinthis&&func.call(context,this[i],i,this))

returntrue;

}

returnfalse;

};

}

if(!Array.prototype.map){

//返回一个数组,现有数组中的每个元素调用提供的函数的返回值。

Array.prototype.map=function(func,context){

varresults=[];

for(vari=0;i<this.length;i++){

if(iinthis)

results[i]=func.call(context,this[i],i,this);

}

returnresults;

};

}

因为exec方法返回数组或null值,并会恰当的类型转换为true和false,上面的代码允许我们像这样使用:[”a”,”b”,”ab”,”ba”].filter(/^a/),返回所有以“a”开始的值:[”a”,”ab”]。

确实,在Firefox中已经实现了Array.prototype.filter,由于exec的间接调用已经在该浏览器中起作用了。但是如果filter没有添加RegExp.prototype.call方法,却无法跨浏览器执行。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类