浅析javascript函数表达式

开始学习javascript函数表达式,仔细阅读下文。

1、一般形式的创建函数,在执行代码之前会先读取函数声明,所以可以把函数声明写在函数调用的下面:

rush:js;"> sayHi(); function sayHi(){ alert("Hi!"); }

2、使用函数表达式创建函数调用前必须先赋值:

rush:js;"> sayHi(); //错误!!函数不存在 var sayHi=function(){ alert("Hi!"); }

3、递归

一般递归

rush:js;"> function factorial(num){ if (num <= 1){ return 1; } else { return num * factorial(num-1); } }

arguments.callee指向正在执行的函数的指针,可以用它来实现递归:

rush:js;"> function factorial(num){ if (num <= 1){ return 1; } else { return num * arguments.callee(num-1); } }

4、闭包(一个函数,这个函数可以访问另一个作用域里的变量)。 创建闭包的常见方式:在一个函数内部创建另一个函数。当函数执行时,会创建一个执行环境和相应的作用域链。闭包只能取得包含函数中任何变量的最后一个值:

rush:js;"> function createFunctions(){ var result = new Array();
    for (var i=0; i < 10; i++){
      result[i] = function(){
        return i;
      };
    }

    return result;
  }

  var funcs = createFunctions();

  //every function outputs 10
  for (var i=0; i < funcs.length; i++){
    document.write(funcs[i]() + "<br />");
  }

上面代码输出的全部是10。这是因为:每个funcs函数都保存着createFunctions()这个活动对象(这是一个函数,也是一个对象,也是一个引用类型Function类型),而createFunctions()这个活动对象有一个变量i,所以,每个funcs都将拥有这个变量i,而createFunctions()这个函数在返回结果时,i已经变成10了。所以funcs数组的每个值都是10.

可以像下面这样改造:

rush:js;"> function createFunctions(){ var result = new Array();
    for (var i=0; i < 10; i++){
      result[i] = function(num){
        return function(){
          return num;
        };
      }(i);
    }

    return result;
  }

调用每个匿名函数时,将i的当前值给了num,而在匿名函数内部,创建并返回num的闭包。这样,返回数组的每个函数都有自己num变量的一个副本。(这段没有说清,读者自己再揣摩,如果有更好的描述方法,请评论文章下面,谢谢)

5、this对象

6、模仿块级作用域(私有作用域) 如下:

rush:js;"> function outputNumbers(count){ for (var i=0; i < count; i++){ alert(i); }
    alert(i);  //count
  }

  outputNumbers(5);

在Java等语言中,for里面的变量i用完就销毁了。而在javascript中,outputNumbers调用生成活动对象,而这个i是属于这个活动对象的,因此从它被定义开始,就可以在函数内部随处访问它,它在该活动对象内部是共有的。

匿名函数的语法(创建私有作用域):

rush:js;"> (function(){ //这里是块级作用域 })();

函数声明放在圆括号中,表示它是一个表达式,而后面再加个括号就可以立即调用它。

如果临时需要一些变量,那么就可以使用私有作用域:

rush:js;"> function outputNumbers(count){
    (function () {
      for (var i=0; i < count; i++){
        alert(i);
      }
    })();

    alert(i);  //causes an error
  }

上面代码中,i就被私有了,在匿名函数(私有域)外部访问i时就会报错,尽管alert依然在活动对象内。

7、私有变量 函数的参数、局部变量以及函数内部定义的其他函数都属于该函数的私有变量。比如:

rush:js;"> function add(num1,num2){ var sum = num1 + num2; return sum; }

有3个私有变量:num1,num2,sum。函数内部可以访问它们,外部就不行了。

特权方法可以访问私有变量:简单说,使用表达式方式给它一个闭包,在闭包内部访问其他函数

rush:js;"> function Person(name){
    var a=0;

    this.getName = function(){
      return name + a;
    };

    this.setName = function (value) {
      name = value;
    };
  }

this.getName、this.setName就是表达式方式,在创建Person实例后,只能通过getName或者setName来访问name、a属性

以上就是本文的全部内容,希望对大家学习的学习有所帮助。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...