第一种张图, 为什么 第一次console.log(idnex) 输出的是0 , 第二次是undefined
第二种张图, 为什么 第一次console.log(idnex) 输出的是0 , 第二次是app object
谢谢!
第一种张图, 为什么 第一次console.log(idnex) 输出的是0 , 第二次是undefined
第二种张图, 为什么 第一次console.log(idnex) 输出的是0 , 第二次是app object
谢谢!
13 回答12.8k 阅读
7 回答2k 阅读
3 回答1.1k 阅读✓ 已解决
2 回答1.2k 阅读✓ 已解决
6 回答928 阅读✓ 已解决
6 回答1.1k 阅读
2 回答1.3k 阅读✓ 已解决
第一次输出是最外层函数中的console.log(index)的输出结果, 内层函数myfunction只被定义没有调用,
输出的undefine是最外层匿名函数(function(){...})()的返回值, 你没有指定返回值,所以是undefined.
类似, 第一次输出是实例app的时候调用的, 第二次输出是语句new app()会返回一个app对象实例.
如果你是想验证closure行为的话, 建议这样改: