JavaScript高级程序设计——第五章引用类型之Function;

Function类型即函数,实际上是对象,因此函数名实际上是一个指向函数对象的指针,不会与函数绑定。并且其他引用类型一样具有属性和方法。

一般使用函数声明:

function sum(sumi,sum2)
{return num1+num2;}
也可用函数表达式定义:

var sum = function(num1,num2)
{return num1+mun2;};
注意:function后面没有函数名,因为没有必要使用,可以通过变量sum访问函数。最后还要加上“;”就像声明其他变量一样。

最后还有一种方法使用Function构造函数:

var sum =new Function
("num1","num2","return num1+num2");//不推荐

前面可以接受任意的参数,最后一位参数被认为是函数体。但这种方法可读性差,并且这种语法会导致解析器解析两次代码,影响性能,不建议使用。

还记得“函数时对象,函数名是指针”的概念么,使用不带圆括号的函数名是访问函数指针,并非调用函数。

function sum(sumi,sum2)
{return num1+num2;}
var anotherSum =sum;
sum=null;
alert(anotherSum(10,10));//20
所以sum设置成“null”,与函数断绝关系,但仍然可以正常调取anotherNum()。

下面介绍几种特殊的情况:

1、重复声明名称相同的函数:

function sum(sumi,sum2)
{return num1+num2;}
function sum(sumi,sum2)
{return num1-num2;}
最后实现为num1-num2。

2、声明在表达式前

alert sum;
function sum(sumi,sum2)
{return num1+num2;}
结果是可以正常运行,因为在代码执行前,解析器已经通过一个函数声明提升(function declaration hoisting)的过程,读取并将函数声明添加到执行环境中。

但如果使用函数声明等价的函数表达式,就为导致错误,因为不是一个函数声明,所以声明提升并不会对其提升,这也是二者的唯一区别。
3、作为值的函数

function callSomeFunction(someFunction,someArgument){
return someFunction(someArgument);
}

callSomeFunction()函数是通用的,要访问函数的指针:不带圆括号“()”,而执行函数需要带圆括号。

4、函数内部属性

函数内部有两个特殊的对象:arguments和this。

arguments是一个类数组对象,包含着传入函数的所有参数。该对象还有一个属性callee,该属性是一个指针,指向拥有这个arguments对象的函数。如下所示:arguments.callee(a)等价于functionname(a).

还有另一个函数对象的属性:caller。使用例如arguments.callee.caller返回包含这个函数的父类函数;

function outer(){
   			inner();
   			alert("1");
   		}
   		function inner(){
   			alert(arguments.callee.caller);
   		}<pre name="code" class="javascript">outer();

 返回 

    function outer(){
    inner();
    alert("1");
    }

但严格模式会出错。

5、函数属性和方法

每个函数包含两个属性:length和prototype。

length属性表示函数希望接受的命名参数的个数

function sayName(name){
     alert(name);
}
alert(sayName.length);//1

prototype是保存它们所有实例方法的真正所在。不可枚举的。

还包含两个非继承的方法:apply(),call()。

<pre name="code" class="javascript">function sayName(name){
     alert(name);
}
window.name="heihei";
var o ={name:"haha"};
sayName.call(window);//heiheisayName.call(o);//haha
 可以用来扩充作用域。 


、、、不好意思  写的不好 请多多见谅





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值