js函数进阶

2016-11-24  本文已影响0人  angelwgh

函数定义

  1. 函数声明
function add(i,j){
    return i+j
}
  1. 函数表达式
var add = function(i,j){
    return i+j;
}
  1. 函数实例化
var add = new Function('i','j','retunr (i+j)'); 

不同函数定义方式的区别:

函数调用

  1. 普通调用模式
    • add(1)
  2. 方法调用模式
    • 调用对象的方法
var myNumber={
    value:1,
    add:function(){
        this.value +=1;
    }
}

myNumber.add();
  1. 构造函数调用模式

  2. apply(call)调用模式

function Point(x,y){
    this.x = x;
    this.y = y;
}
 Point.prototype.move = function(x,y){
    this.x +=x;
    this.y += y;
 }

 var p = new Point(0,0);
 p.move(2,2);
 var circle = {x:1,y:1,r:1};
 p.move.apply(circle,[2,1]);
 //p.move方法里的this指向circle对象,数组[2,1]里的2个元素作为参数传入方法

函数调用时this的指向

arguments

函数调用时,会给本地作用域添加另一个对象:arguments,用于获取函数实参

函数传参

闭包

如果一个函数访问了它的外部变量,那么它就是一个闭包。

注意,外部函数不是必需的。通过访问外部变量,一个闭包可以维持(keep alive)这些变量。在内部函数和外部函数的例子中,外部函数可以创建局部变量,并且最终退出;但是,如果任何一个或多个内部函数在它退出后却没有退出,那么内部函数就维持了外部函数的局部数据。

function foo(x) {
var tmp = 3;
return function (y) {
    alert(x + y + tmp);
    x.memb = x.memb ? x.memb + 1 : 1;
    alert(x.memb);
    }
}
var age = new Number(2);
var bar = foo(age); // bar 现在是一个引用了age的闭包
bar(10);

First-class function

function Point(x,y){
    this.x = x;
    this.y = y;
}
 Point.prototype.move = function(x,y){
    this.x +=x;
    this.y += y;
 }

 var p = new Point(0,0);
 p.move(2,2);
 var circle = {x:1,y:1,r:1};
 var circlemove=p.move.bind(circle,[2,1]);
 circlemove();
 
上一篇 下一篇

猜你喜欢

热点阅读