锁定老帖子 主题:JavaScript内核系列 第4章 函数
精华帖 (4) :: 良好帖 (17) :: 新手帖 (0) :: 隐藏帖 (6)
|
|
---|---|
作者 | 正文 |
发表时间:2010-04-19
用内核有点标题党,Core更偏向核心的意思。JavaScript基础的书已经很多了,楼主也要出书吗? 最好能偏向应用实践的。
|
|
返回顶楼 | |
发表时间:2010-04-19
ahuango 写道 用内核有点标题党,Core更偏向核心的意思。JavaScript基础的书已经很多了,楼主也要出书吗? 最好能偏向应用实践的。
就是因为基础书太多,所以这个系列里没有诸如关键字,语句,表达式这样的内容,像犀牛这样的书,只能在书桌上读,想找本能捧在手里的还真不容易,所以想把这些比较核心的东西整理出来。 个人倾向于学院派,现在比较流行的面向实践的书,环境配置占一定的篇幅,各种框架的比较占一定的篇幅,基础知识占一定的篇幅,所以书本弄的非常厚,内容庞杂,反而失之精简。 |
|
返回顶楼 | |
发表时间:2010-04-19
var str = "global"; function scopeTest(){ print(str); var str = "local"; print(str); } scopeTest(); 这个例子非常有迷惑性,可以讲得更深入点。因为提到“词法作用域”,就必须得同时提到“作用域链”,两者结合才能有效理解。 对此例我的解释如下,不对请指正: 第1行的str(global)在定义时首先被存入作用域链的头部即全局作用域; 在调用scopeTest时,js解释器生成1个调用对象(call object),并将scopeTest内通过var定义的str设为它的一个属性,然后再把这个对象加到作用域链的最前端,通俗理解即具有最优先的访问权。 在访问str时,首先查询scopeTest的调用对象,如果从中没找到str则查询仅挨该对象的上一个作用域,以此类推直至全局作用域。 此例中从调用对象中即可查到str,因此全局对象中的str被覆盖:第3行,调用对象中有str定义但未赋值,因此为undefined;第4行,赋值;第5行,有值,所以是local。 var str = "global"; function scopeTest(){ print(str); //global } scopeTest(); 为什么这里是global?因为scopeTest的调用对象里没有str的定义,因此必须查询全局作用域,所以得出global。 为什么“词法作用域”的效果是“函数在定义它的作用域中执行,而不是执行它的环境”?那是因为函数始终只能沿着定义它时就确定了的“作用域链”逐级访问变量,与外界执行环境无关: var str = "global"; function scopeTest(){ alert(str); } (function(){ var str="aaa"; scopeTest();//global })(); 个人理解:“词法分析”的作用是确定函数的上级作用域链,这点待求证。 |
|
返回顶楼 | |
发表时间:2010-04-19
hyj1254 写道 var str = "global"; function scopeTest(){ print(str); var str = "local"; print(str); } scopeTest(); 这个例子非常有迷惑性,可以讲得更深入点。因为提到“词法作用域”,就必须得同时提到“作用域链”,两者结合才能有效理解。 对此例我的解释如下,不对请指正: 第1行的str(global)在定义时首先被存入作用域链的头部即全局作用域; 在调用scopeTest时,js解释器生成1个调用对象(call object),并将scopeTest内通过var定义的str设为它的一个属性,然后再把这个对象加到作用域链的最前端,通俗理解即具有最优先的访问权。 在访问str时,首先查询scopeTest的调用对象,如果从中没找到str则查询仅挨该对象的上一个作用域,以此类推直至全局作用域。 此例中从调用对象中即可查到str,因此全局对象中的str被覆盖:第3行,调用对象中有str定义但未赋值,因此为undefined;第4行,赋值;第5行,有值,所以是local。 var str = "global"; function scopeTest(){ print(str); //global } scopeTest(); 为什么这里是global?因为scopeTest的调用对象里没有str的定义,因此必须查询全局作用域,所以得出global。 为什么“词法作用域”的效果是“函数在定义它的作用域中执行,而不是执行它的环境”?那是因为函数始终只能沿着定义它时就确定了的“作用域链”逐级访问变量,与外界执行环境无关: var str = "global"; function scopeTest(){ alert(str); } (function(){ var str="aaa"; scopeTest();//global })(); 个人理解:“词法分析”的作用是确定函数的上级作用域链,这点待求证。 这个朋友分析的非常好,调用对象(call object)我没有提及,是一个严重的bug,谢谢你的指正。 也希望大家多提意见,最后我会一一检查,汇总成比较完善的系列,谢谢! |
|
返回顶楼 | |
发表时间:2010-04-19
为什么有人投隐藏呢?貌似文章不符合隐藏的条件吧?难道是点击收藏的时候点错了?
|
|
返回顶楼 | |
发表时间:2010-04-20
受教了,支持一下
|
|
返回顶楼 | |
发表时间:2010-04-20
JavaScript太强大了,要是学好jquery那就可以少做很多事情了
|
|
返回顶楼 | |
发表时间:2010-04-20
yongdi2 写道 JavaScript太强大了,要是学好jquery那就可以少做很多事情了
由于JavaScript的双重特性,jQuery只是在函数式这个特征上对JavaScript做了延伸,所以使用jQuery写代码的时候会感觉到非常的舒服,比如jQuery中的map/grep,以及遍历集合用的each等,都直接来源于lisp。 其实jQuery的集合对象,几乎完全可以和Lisp中的列表对应起来。 |
|
返回顶楼 | |
发表时间:2010-04-20
Pretty Good~~~~
简直太棒了~~~ 楼主辛苦~~ |
|
返回顶楼 | |
发表时间:2010-04-20
有时间就在看楼主的文章,楼主用js有开发过大的工具或项目吗?一般的项目几乎都会用到js,但一些很少见的语法,用法,基本不会用到,感觉楼主写这么细,对大部分开发者有用吗?谢谢。
|
|
返回顶楼 | |