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
用call和apply应用另一个函数(类)以后,当前的函数(类)就具备了另一个函数(类)的方法或者是属性,这也可以称之为“继承”;
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;
该对象代表正在执行的函数和调用它的函数的参数,属于执行函数时创建的隐含对象,它具有数组一样的 访问性 质和方式,但不属于数组的对象 ,它存储的是实际传递给函数的参数,而不是函数定义的参数列表;
如:函数:定义函数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
用call和apply应用另一个函数(类)以后,当前的函数(类)就具备了另一个函数(类)的方法或者是属性,这也可以称之为“继承”;
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;
相关文章推荐
- javascript概念部分
- JavaScript高级部分概念用法
- 《JavaScript核心概念》基础部分重点摘录
- 轻松学习 JavaScript——第 3 部分:函数中的默认参数
- javascirpt历史澄清误解基本概念特点编程语言web2.0网页javascript - javascirpt知识大全
- 读书笔记之: 操作系统概念(第6版)-第五部分 分布式系统(分布式系统, 保护与安全)+历史概览
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- javascript 基础概念补充点
- javascript理解04-函数的概念及作用
- web前端 基础部分(三) JavaScript
- javascript,jquery(闭包概念)
- javascript高级部分需要注意的地方
- firefix和ie中javascript使用区别(部分)
- ObjC运行时部分概念解析(二)
- JavaScript基础 Math.floor() 向下取整 小数部分不四舍五入了,有小数就舍去。小数再大,都舍
- JavaScript 工作机制:第 1 部分
- Javascript笔记部分
- 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求
- 轻松学习 JavaScript——第 1 部分:了解 let 语句
- 全面理解javascript的caller,callee,call,apply概念[转载]