百科问答小站 logo
百科问答小站 font logo



关于下面这段代码的报错是怎么个过程? 第1页

  

user avatar   rednaxelafx 网友的相关建议: 
      

在执行阶段报错。

题主这个问题还不需要关心编译的过程。这段代码编译是没问题的,唯一要留意的是变量提升(

variable hoisting

),但在这里就算不看变量提升也不影响结果。

题主原本的代码:(格式化一下)

       var foo = {   fn1: function() { return 1; },   fn2: foo.fn1()                // TypeError: Cannot read property 'fn1' of undefined }      

这个代码可以等价看作拆解的形式:

       var foo             // foo is undefined now var tmp = { } tmp.fn1 = function() { return 1; } tmp.fn2 = foo.fn1() // TypeError: Cannot read property 'fn1' of undefined foo = tmp      

赋值表达式或者带初始化的变量声明都是,要在赋值符号的右手边的表达式求值完成之后,才会把右手边的值赋予左手边的表达式。

而不是题主显然以为的:

       var foo             // foo is undefined now foo = { } foo.fn1 = function() { return 1; } foo.fn2 = foo.fn1() // works!      

问题解决。




  

相关话题

  为何以下javascript代码在chrome88和firefox85中执行结果为false? 
  如何去判断 JS 字符串中含某个字符串? 
  如何看待React.js 官方文档支持乌克兰 ,释放了哪些信息? 
  如何看待React.js 官方文档支持乌克兰 ,释放了哪些信息? 
  用 // 代替 http:// 有什么好处? 
  JavaScript 中,定义函数时用 var foo = function () {} 和 function foo() 有什么区别? 
  对于一般程序员来说,怎么防止为了潮流技术 疲于奔命? 
  既然引用计数在做 GC 时有性能问题,为什么智能指针会广泛应用它? 
  为什么没有介绍谷歌JavaScript V8引擎的书? 
  大公司实习经历对下一份工作能带来多少帮助? 

前一个讨论
如何提升ASP.NET网站首次打开速度?
下一个讨论
为什么坐火车要付钱?





© 2025-05-31 - tinynew.org. All Rights Reserved.
© 2025-05-31 - tinynew.org. 保留所有权利