js中Function引用类型常见有用的方法和属性详解
Function类型
函数由于是Function类型的一个实例,所以函数名就是一个指向函数对象的指针,不会与某个函数死死的连接在一起,这也导致了js中没有真正的重载,但好处是,函数对象可以作为另一个函数的参数或是返回值;
访问一个函数对象的指针而不是执行函数本身不能加括号
varfunc=newFunction("x","y","returnx+y");//构造函数来实例化一个Function类型,但不推荐使用 functionfunc(x,y){ returnx+y; }//函数声明js引擎会将所有的函数声明提升到顶部 varfunc=function(x,y){returnx+y};//函数表达式变量的赋值,变量func保存着function(x,y){returnx+y}这个对象
Function类型中,有两个特殊的对象:arguments和this,前者里面有传入函数中所有的参数,还有一个callee属性,这是个指针指向拥有这个属性的Function实例;而this这个指针指向执行环境,也就是Global类型的一个实例.在浏览器中是一个窗口.
functionb(){ console.log(arguments.callee); }
Function类型的属性和方法
length//Funciton实例期望接收形式参数的个数 prototype// apply();//非继承的方法 //apply(Function实例运行的作用域:this,Array实例或arguments) call();//非继承的方法 //call(Function实例运行的作用域:this,arg1,arg2,...) // bind(X);//将Function的实例的this指向对象X
除此之外,Function类型中还有一个特殊的属性:caller,这是个指针,在严格模式下不能对这个属性赋值.
Function类型一个实例a调用了Function类型的另一个实例b,那么实例b中的caller属性就会指向实例a;
functiona(){ b(); } functionb(){ console.log(arguments.callee.caller); }
以上就是本次介绍的全部相关知识点,感谢大家的学习和对毛票票的支持。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。