JavaScript中的函数

  几个要点:

  1. 不能指定传入参数的类型,可以使用typeof进行检测
  2. 参数个数不会被检测,如果传入的参数过多,则多余的参数被忽略;传入过少,则剩余参数设为undefined.
  3. 函数可以嵌套函数,但是只参在函数的最顶层。
  4. 函数直接量:未命名函数。例如:
    var f = function(x){return x*x;};
     或:
    var f = function fact(x) { if (x<=1) return 1; return x * fact(x-1);};
    
    注意到 fact在外部没法再访问,只是用于实现递归调用。
  5. 可变长度参数列表: Arguments对象
    在函数内,arguments标识符具有特殊含义,它表示参数列表对象,类似于数组,可以用来获取传入的参数值。例如:
        f("aa","bbb","ccc");
        function f(){
            var length = arguments.length;
            for(var i = 0;i<length;i++){
                document.writeln(arguments[i]);
            }
        }
     其中如果函数定义了参数,例如f(x,y){};则arguments[0]=x, arguments[1]=y。
    注:注意如果定义了同名的变量,则arguments会被隐藏。
  6. arguments的另一个属性callee,用来引用当前函数。
  7. 函数可以看作是一种特殊的变量,可以把函数赋值一个变量或属性,而功能不变化。例如:
    var o = new Object;
    o.square = function(x) {return x*x;};
    y = o.square(16);
    
    var a = function(x) {return x*x;};
    
  8. 作为对象的一个方法时,用this引用当前对象;如果是函数则引用全局对象
  9. 构造函数:后面再介绍

二、函数的属性和方法

 

函数的typeof运算结果返回"function",证明函数是一种特殊的数据类型。因此它和对象一样,具有属性和方法。

 

1. length属性: 只读属性,返回函数定义中形参个数,与实际传入参数无关;且该属性在函数内外都可使用。例如:

    document.write("</br>Outside: "+a.length);
    a();
    function a(a, b, c){
        document.write("</br>Inside: "+Function.length);
    }

 

2. prototype属性:后面再介绍

 

 

3. 自定义函数属性

 

因为函数也可以看成一种对象,因此可以给它定义变量,例如:

uniqueIngeger.counter = 0;

function uniqueInteger(){
  return uniqueInteger.counter++;
}
 

4. apply()和call()方法

 

f.call(o, 1, 2 );
 

相似于:

 

o.m = f;
o.m(1, 2);
delete o.m;
 

apply与call相似,只不过传递给函数的参数由数组指定:

 

f.apply(o, [1, 2]);

 

对象o可以是空,例如: Math.max.apply(null, array_of_numbers);

 

三. 函数作用域和闭包

 

JavaScript函数是将要执行的代码以及这些代码的作用域构成的一个综合体,在计算机科学术语中,这种代码和作用域的综合体叫做闭包。所有的JavaScript函数都是闭包。

 

例如,想编写一个能够通过记住一个值的函数,一种简单的实现是使用函数的变量:

 

uniqueID = function(){
      if(!argument.callee.id) argument.callee.id = 0;
      return argument.callee.id++;
};

 

每次调用的时候,返回的id值都加1, 但是并不能阻止有人直接对id赋值,例如: uniqueID.id = 0;

 

要解决此类问题,可以使用闭包:

 

uniqueID = (function(){
        var id = 0;
        return function() { return id ++;};
}) ();

 

这里uniqueID引用的是内部返回的函数,并且此函数引用的值是定义有外层函数中,因此不会被uniqueID修改。

 

 

四、Function()构造函数

 

可以使用Function构造函数来创建一个函数的例子,例如:

 

var f = new Function("x", "y", "return x*y;");
 

上例创建了一个新的函数,它类似于:

 

function f(x, y){return x*y;}
 

Function构造函数的特点:

  • Function构造函数允许JavaScript代码被动态的创建并且在运行时编译,例如全局的eval()函数
  • Function构造函数解析函数体,并且每次调用的时候都创建一个新的函数对象。
  • 最后,关于Function函数非常重要的一点就是:它所创建的函数并不使用词法作用域,相反,它们总是当作顶层的函数一样来编译。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值