没有合适的资源?快使用搜索试试~ 我知道了~
js当一个变量为函数时 应该注意的一点细节小结
需积分: 0 0 下载量 73 浏览量
2020-10-28
05:54:24
上传
评论
收藏 33KB PDF 举报
温馨提示
试读
1页
变量testFun为一个匿名函数,匿名函数返回的一个testFun.init对象(也是一个匿名函数)
资源推荐
资源详情
资源评论
js当一个变量为函数时当一个变量为函数时 应该注意的一点细节小结应该注意的一点细节小结
变量testFun为一个匿名函数,匿名函数返回的一个testFun.init对象(也是一个匿名函数)
先看一段简单的代码:
复制代码 代码如下:
var testFun=function (name,age){
var job='Flash Develop';
return new testFun.init(name,age,job);
}
testFun.init=function(name,age,job){
return 'name:'+name+',age:'+age+',job:'+job+'';
}
alert(testFun('vincent',30)); //[object Object]
代码很简单,变量testFun为一个匿名函数,匿名函数返回的一个testFun.init对象(也是一个匿名函数)。但对于一些新手有
时会误解为:testFun是返回的一个testFun.init对象。他可能会这样想,在匿名函数function(name,age)构建过程中,又用到了
testFun. 此时testFun还在构建中,应该还没有存在,testFun.init更没有存在,怎么就可以用testFun.init呢?
其实这样想是存在了一个误区:把testFun与testFun()等同起来了,如果testFun是返回的一个testFun.init对象,代码应该是
testFun=function(name,age){… …}()。正确的理解应该是这样的,testFun只是一个函数,当你把一个函数赋于它时,它就已
经存在了,哪怕函数返回的是undefined或null,它本身仍然是Function,只有testFun()执行后返回值才是undefined或null。返回
值是testFun()执行的结果,结果返回后,就不再与testFun有任何关系。如:
复制代码 代码如下:
var testFun=function(){
return undefined;
}
var result=testFun();
alert(testFun); // function () {return undefined;}
alert(result); // undefined result与testFun不再有任何关系
所以,当赋于testFun一个匿名函数后,它就一直存在着,直到赋于它另外一个值。对于testFun.init你可以这样简单的去理
解:
testFun.init=function(name,age){}.init=function(name,age.job){… …}
综上所述,回头再看testFun是一个函数,而testFun()则是(function(name,age,job){return
'name:'+name+',age:'+age+',job:'+job+''; })()
为了便于理解,可以把代码精简为:
复制代码 代码如下:
var testFun=function(){}
testFun.init=function(){}
只是testFun()没有返回一个testFun.init对象罢了。
资源评论
weixin_38661852
- 粉丝: 5
- 资源: 978
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功