码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript权威设计--JavaScript函数(简要学习笔记十一)

时间:2015-09-18 23:24:50      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:

1.函数调用的四种方式
第三种:构造函数调用
如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内。这和函数调用和方法调用是一致的。但如果构造函数没有形参,JavaScript构造函数调用的语法是允许省略实参列表和圆括号的。
如:
var o=new Object();
//->等价于
var o=new Object;
 
第四种:使用call()与apply()间接调用(放在后面详细说明)
 
2.函数的实参与形参——可选形参
先看一个例子:
function getA(o,/*optional*/ a){
    if(a===undefined){
        a=[];
    }
    for(var pro in o){
        a.push(pro);
    }
}
上面这个函数调用可以传入一个参数,或者两个参数。
a:一般会在可选形参的前面加上/*optional*,来强调形参是可选的。
b:还有一般将可选参数放在参数列表的最后。
c:如果可选形参不传入实参的话,该参数就会被默认为undefined。
d:当然了,你也可以参入null或undefined作为占位符。
 
3.可变长的实参列表:实参对象
有时候我们调用函数时,传递的参数超过函数定义的个数时,没有办法直接获得未命名值得引用。
虽然JavaScript的默认行为会把多出的参数自动省略。但是我们有时候就是需要获得这些个多出的参数,那咋办?(是不是有点贱?- -)
这时钢铁侠就来了!额!不!是实参对象就来解决这个问题了。
在函数体内,arguments就是指向实参对象的引用。实参对象是一个类数组对象。这样就可以通过下标来访问了,而不需要通过名字来访问。
duang~
来个例子:
function a(x,y){
    return x*y;
}
//调用
a(‘10‘,‘10‘,‘11‘);
 
11默认省略,如果我们想获得它,可以把上面的例子改下:
 
function a(x,y){
    if(arguments.length!=2){
        return x*y;
    }else if(arguments.length>2){
        return arguments[2];    //这里的arguments[2]就是11了
    } 
}
 
实参对象有一个重要的用处,就是让函数可以操作任务数量的实参。
例如:
function max(/*...*/){
    var max=Number.NEGATIVE_INFINITY;
    for(var i=0;i<arguments.length;i++){

        if(arguments[i]>max){
            max=arguments[i];
        }
    }
    return max;
}

var l=max(1,2,3);
alert(l)
 
4.JavaScript中,函数不仅作为一种语法,可以定义可以调用。也是值。
下面来看一个函数定义:
function squ(x){
    return x*x;
}
 
理解:这个定义创建一个新的函数对象,并将其赋值给变量squ。
函数的名字实际上是看不见的,它(squ)仅仅是变量的名字,这个边变量指代函数对象。函数还可以赋值给其他的变量,并且仍可以正常工作。
 
var s=squ;    //这里的s与squ指代同一个函数
squ(4);    //16
s(4);    //16
 
同样可以将函数赋值给对象的属性。
 
var o={
    squ:function(x){
        return x*x;
    }
}
var y=o.squ(4);    //16
 
 

JavaScript权威设计--JavaScript函数(简要学习笔记十一)

标签:

原文地址:http://www.cnblogs.com/zqzjs/p/4820486.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!