您的位置:首页 > Web前端 > JavaScript

JavaScript基础篇(四)— — 函数(1)

2016-04-26 12:53 309 查看
[b]一、函数基础[/b]

  1、返回值:如果某个函数没有显式的return返回值,默认它的返回值为undefined

  2、参数:内建变量arguments,能返回函数所接收的所有参数

    


  3、预定义(内建)函数 —— isNaN:

    a、检测parseInt / parseFloat调用是否成功。

    


    b、NaN不存在等值的概念, 也就是说表达式NaN === NaN 返回的是false

[b]二、函数的变量作用域[/b]

  1、变量声明:尽管在全局作用域可以不用var, 但是声明局部变量中必须使用var语句,否则相当于全局变量

    


  2、变量提升:函数域优先于全局域,所有局部a会覆盖掉所有与它同名的全局变量,尽管在alert( )第一次调用时, a还没有被正式定义(即该值为undefined),但该变量本身已存在本地空间了。这种特殊的现象叫做提升(hoisting)


=相当于=


匿名函数也受命名提升的影响


  


[b]三、函数也是数据[/b]







匿名回调函数

[b]四、即时(自调)函数[/b]

  表示函数在定义后立即调用,写法有如下两种格式:

  

==


  


[b]五、闭包[/b]

 闭包就是拿到本不该拿的东西

  1、作用域链

  




  2、理解this【谁调用它,this就指向谁】

  








  2、闭包两种方式:

  

  


  3、循环中的闭包

  




  其中的陷阱是函数带()才是执行函数!上面代码翻译一下就是:

var arr= new Array(), i;
arr[0] = function(){ return i; }; //没执行函数,函数内部不变,不能将函数内的i替换!
...
arr[2] = function(){ return i; }; //没执行函数,函数内部不变,不能将函数内的i替换!
i = 3;
funcs = arr;//函数数组
arr= null;
console.log(i); // funcs[0]()就是执行 return i 语句,就是返回3
...
console.log(i); // funcs[2]()就是执行 return i 语句,就是返回3


  4、理解闭包

  






闭包总结:1、有权访问另一个函数作用域内变量的函数。

     2、闭包就是一个函数引用另外一个函数的变量,因为变量被引用着所以不会被回收,因此可以用来封装一个私有变量。这是优点也是缺点,不必要的闭包只会徒增内存消耗!

来源:《JavaScript面向对象编程指南(第2版)》

《带你一分钟理解闭包–js面向对象编程》/article/7547606.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: