时间:2021-05-26
曾经ECMAScript4建议指出这个功能将会增加到ES4规范中,但后来的在ES4-discussmailinglist的讨论中,这个建议可能被废除。
然而,你可以通过增加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方法的返回值。使用上面的方法,无论在什么情况下,使我们正常地使用正则表达式和函数变得容易得多。一些很明显的例子,比如这些在JavaScript1.6的数组迭代中很有用。下面的filter,every,some,和map方法的执行可以跨浏览器。
if(!Array.prototype.filter){
//返回一个数组,如果提供的过滤函数返回true,则返回存在的数组中的元素。
Array.prototype.filter=function(func,context){
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方法,却无法跨浏览器执行。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
不多说,直接上代码,winform下button1调用js函数,从html页面获取值,然后JS调用WINFORM的函数,传送获取到的值到winform并通过me
Js函数调用的方式有如下几种情况:(1)具名函数直接调用复制代码代码如下:functionfoo(){}foo();(2)匿名函数通过引用来调用复制代码代码如下
好,看看匿名函数的如何被调用。1、执行后得到返回值的函数调用Js代码复制代码代码如下://方式1,调用函数,得到返回值。强制运算符使函数调用执行(functio
js调用后台,后台调用前台等方法总结1.javaScript函数中执行C#代码中的函数:方法一:1、首先建立一个按钮,在后台将调用或处理的内容写入Button1
JS中的函数简介JS中的函数是一种通过调用来完成具体业务的一段代码块。最核心的目的是将可重复执行的操作进行封装,然后供调用方无限制的调用。JS中的函数的定义JS