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

javascript学习笔记:函数与方法

2014-08-04 16:37 323 查看
函数:

1、arguments:代表参数,不是数组,但是具有length属性,可以用下标[]访问

2、arguments.callee:当前正在执行的函数

3、arguments中的元素与参数是同义词

function(a,b){};argument[0]就是a,改变任何一个,另一个都改变了

4、函数的参数类型不需要指定(不同于静态语言)

方法:

1、当一个函数在一个对象上调用的时候,这个函数称为方法。(这应该不是定义吧,但是《javascript权威指南(第五版)》就这么写的)。

2、方法的重要特点:

在方法体中,关键字this的值就是调用方法的对象(这个跟java没有区别)。

对于不是方法的函数来说,this关键字引用全局对象。这个还好理解,相当于全局对象是这一类函数的调用对象。

书上的例子,this值得注意。

var calculator = {
  operand1:1,
  operand2:1,
  compute:function(){
    this.result = this.operand1 + this.operand2; //在compute内部,this仍然是指 calculator指向的对象
  }
};
calculator.compute();
console.log(calculator.result);


下面是一个改造的例子,说明:当一个函数作为函数而不是方法调用的时候,this关键字引用全局对象。

var o = {
    a:1,
    calculator : function(){
      console.log(this);//Object { a=1,  calculator=function()}
      function compute(){
        console.log(this);//Window about:ntab
      };  
      compute();
    }
};
o.calculator();
console.log(this);//Window about:ntab


以上代码在定义了o之后,调用了o的方法calculator,而在calculator内部定义了一个嵌套函数compute,它是作为函数而非方法存在的,定义之后直接调用。

在calculator方法中,this指向的调用它对象(就是o引用的对象),这符合方法的特点。
compute也是作为函数而不是方法来调用的,因此这里this引用的是全局对象。

控制台打印的结果也印证了第二点。最后一行console.log(this)和compute中的console.log(this)都打印出window。

关于嵌套函数中this的说明,《javascript权威指南(第五版)》中文版说的有点绕口,我理认真看了三遍才明白,原文如下:

“当一个函数作为函数而不是方法调用的时候,这个this关键字引用全局对象。容易令人混淆的是,当一个嵌套的函数(作为函数)在一个包含的函数之中调用,而这个包含的函数却是作为方法调用的,这也是成立的:this关键字在包含的函数中有一个值,但是它却(不太直观地)引用嵌套的函数体的内部的全局对象。”

要理解这段话,首先要弄明白去嵌套的函数和包含的函数,嵌套函数不用说了,包含的函数其实就是指外部函数,这个名字不好理解,叫外部函数就好了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: