7x24小时售后服务
5倍故障时长赔付
15天无理由退款
N对一管家服务
让我们的顾问联系您
如果函数A被函数B调用,那么在被调用的期间,函数A的caller就是函数B。如果一个函数不是被另一个函数调用的,caller就为null。看下面的代码就很容易理caller的基本性质。
function a(){
return a.caller;
};
function b(){
alert(a.caller); //null 此刻的a没被调用
alert(a()); //函数b
alert(a.caller); //null 此刻的a没被调用
};
alert(a());//null 是在全局中调用的,不是被某个函数调用的
b();
caller的基本概念虽然很简单但是有一处兼容性问题。当一个函数被eval执行时,由于eval有global和local两种模式,所以执行起来会有很大的差异。下面是测试代码,由于实验结果差异太大我就不逐个浏览器截图了,会做一个表格贴出数据。
function f(){
eval(“g()”);
(1,eval)(“g()”);
};
function g(){
alert(g.caller);
};
f();
方式\环境 Chrome Firefox Opera IE9+ IE8-
eval f f f f null
(1,eval) eval null f f null
果然很纠结吧,特别是Chrome的行为诡异到不可思议。不过真正遇到eval+caller的情况不多这些东西也不用太纠结。至于(1,eval)这种用法我以后的文章会说道,这里就简单的说一下,这个用法在现代浏览器中是在全局作用域执行代码。这篇文章也就到这儿吧,内容本来就不多。
本文来源于成都网站建设公司、成都网站设计制作公司与成都APP开发公司-桔子科技公司!
成都网站建设,成都网站设计,成都网站制作,成都网页设计,成都网站建设公司 ,成都网站设计公司, 成都网站制作公司,成都手机网站建设,手机网站建设,成都APP开发,APP开发,成都建网站,成都做网站,成都微信网站建设,成都微商城网站建设,成都商城网站建设,成都网络公司。
7x24小时售后服务
5倍故障时长赔付
15天无理由退款
N对一管家服务
让我们的顾问联系您
川公网安备 51010502010278号
ICP备案号:蜀ICP备10206569号-2