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

javaScript部分概念

2007-10-26 10:23 471 查看
1.隐含参数:arguments
  该对象代表正在执行的函数和调用它的函数的参数,属于执行函数时创建的隐含对象,它具有数组一样的 访问性    质和方式,但不属于数组的对象 ,它存储的是实际传递给函数的参数,而不是函数定义的参数列表;
 如:函数:定义函数Test(a,b,c),直接调用:Test('参数1','参数2')
        则:
arguments.length = 2     arguments[0] = '参数1'   arguments[0] = '参数2'
                Test.length = 3
2.caller
   返回调用该函数的函数的引用,如果由顶层调用,则返回null;
  如:定义函数:
            A(){
                A.caller
                };  
            B(b){ A() };
    则在执行B函数时,B调用了A函数,A.caller则返回B函数的引用;
3.callee  :
  用法:arguments.callee
    返回正被执行的 Function 对象
    callee拥有length属性,这个属性有时候用于验证还是比较好的。arguments.length是实参长度,arguments.callee.length是形参长度,由此可以判断调用时形参长度是否和实参长度一致
4.call/apply:
    函数绑定到另外一个对象上去运行,两者仅在定义参数方式有所区别
  apply(thisArg,argArray);

    call(thisArg[,arg1,arg2…] ]);
  没有提供 thisArg参数,那么 Global 对象被用作 thisArg
 用callapply应用另一个函数(类)以后,当前的函数(类)就具备了另一个函数(类)的方法或者是属性,这也可以称之为“继承”;
  call(apply)方法可将一个函数的对象上下文(Function Context)从初始的上下文改变为由 thisObj 指定的新对象;
   如:
   var changed={ item:"banana", act: "eating" };
var original={
        item: "chair",
 act: "sitting in",
 ask: function(){
  return "who's been "+this.act+" my "+this.item;
 }
};
original.ask();    == who's been sitting in my chair;
original.ask.call(changed)   ==  who's been eating in my banana;

 
 
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息