码迷,mamicode.com
首页 > 其他好文 > 详细

函数深入理解---函数的内部属性arguments和this

时间:2014-12-12 18:48:48      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   ar   color   使用   sp   for   on   

arguments

function say(num){
    /*
        在函数对象中有一个属性叫做arguments,通过这个属性可以获取相应的参数值,这个属性
        是一个数组,其实就是传递进来的参数
    */
    console.log(arguments.length);
    for(var i=0;i<arguments.length;i++){
        console.log(arguments[i]);
    }
    console.log(num);
}
/*
    在arguments这个对象中有一个callee的方法,arguments.callee(arg)
    可以反向的调用
*/

//say(1,2,3);

//此时和函数名耦合在一起
//return num * factorial(num-1);
//以下就实现了函数名的解耦合,在js中通常都是使用这种方式做递归
function factorial(num){
    if(num<=1){
        return 1;
    }else{
        return num*arguments.callee(num-1);
    }
}

/*
    以上是一个求阶乘的函数,以上递归调用的函数名称和原有函数名耦合在一起了
    如果将来这个函数名称更改之后递归调用就会失效
*/
var cf = factorial;
//此时不会报错
console.log(cf(5));
factorial = null;

//此时由于cf这个函数依然使用factorial这个名称来调用,但是factorial已经指向null了,所以就会报错
//递归调用就会失效

console.log(cf(5));


this

/* 当需要创建一个类的时候,设置类的属性和方法需要通过this关键字来引用 但是特别注意:this关键字在调用时会根据不同的调和对象变得不同 */ var color = ‘red‘; function showColor(){ console.log(this.color); } //创建了一个类,有一个color的属性和一个show的方法 function Circle(color){ this.color = color; this.showColor = showColor; } var c = new Circle(‘yellow‘); //使用c来调用showColor 方法,等于调用了showColor()方法 //此时的this是c,所以color就是yellow c.showColor();//yellow //此时调用的对象等于是window,showColor的this就是window,所以就会找window中color showColor(); //red

 

函数深入理解---函数的内部属性arguments和this

标签:style   blog   io   ar   color   使用   sp   for   on   

原文地址:http://www.cnblogs.com/leole/p/4160253.html

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