论坛首页 Web前端技术论坛

JavaScript内核系列 第4章 函数

浏览 11988 次
精华帖 (4) :: 良好帖 (17) :: 新手帖 (0) :: 隐藏帖 (6)
作者 正文
   发表时间:2010-04-19  
用内核有点标题党,Core更偏向核心的意思。JavaScript基础的书已经很多了,楼主也要出书吗? 最好能偏向应用实践的。
0 请登录后投票
   发表时间:2010-04-19  
ahuango 写道
用内核有点标题党,Core更偏向核心的意思。JavaScript基础的书已经很多了,楼主也要出书吗? 最好能偏向应用实践的。


就是因为基础书太多,所以这个系列里没有诸如关键字,语句,表达式这样的内容,像犀牛这样的书,只能在书桌上读,想找本能捧在手里的还真不容易,所以想把这些比较核心的东西整理出来。

个人倾向于学院派,现在比较流行的面向实践的书,环境配置占一定的篇幅,各种框架的比较占一定的篇幅,基础知识占一定的篇幅,所以书本弄的非常厚,内容庞杂,反而失之精简。
0 请登录后投票
   发表时间: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
})();   

个人理解:“词法分析”的作用是确定函数的上级作用域链,这点待求证。
0 请登录后投票
   发表时间: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,谢谢你的指正。

也希望大家多提意见,最后我会一一检查,汇总成比较完善的系列,谢谢!
0 请登录后投票
   发表时间:2010-04-19  
为什么有人投隐藏呢?貌似文章不符合隐藏的条件吧?难道是点击收藏的时候点错了?
0 请登录后投票
   发表时间:2010-04-20  
受教了,支持一下
0 请登录后投票
   发表时间:2010-04-20  
JavaScript太强大了,要是学好jquery那就可以少做很多事情了
0 请登录后投票
   发表时间:2010-04-20  
yongdi2 写道
JavaScript太强大了,要是学好jquery那就可以少做很多事情了


由于JavaScript的双重特性,jQuery只是在函数式这个特征上对JavaScript做了延伸,所以使用jQuery写代码的时候会感觉到非常的舒服,比如jQuery中的map/grep,以及遍历集合用的each等,都直接来源于lisp

其实jQuery的集合对象,几乎完全可以和Lisp中的列表对应起来。
0 请登录后投票
   发表时间:2010-04-20  
Pretty Good~~~~
简直太棒了~~~
楼主辛苦~~
0 请登录后投票
   发表时间:2010-04-20  
有时间就在看楼主的文章,楼主用js有开发过大的工具或项目吗?一般的项目几乎都会用到js,但一些很少见的语法,用法,基本不会用到,感觉楼主写这么细,对大部分开发者有用吗?谢谢。
0 请登录后投票
论坛首页 Web前端技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics