码迷,mamicode.com
首页 > 编程语言 > 详细

javascript all,call区别与用法

时间:2014-11-11 22:59:11      阅读:257      评论:0      收藏:0      [点我收藏+]

标签:javascript   function   



我们发现apply()和call()的真正用武之地是能够扩充函数赖以运行的作用域,如果我们想用传统的方法实现。

1、每个函数都包含两个非继承而来的方法:apply()和call()。 
2、他们的用途相同,都是在特定的作用域中调用函数。 
3、接收参数方面不同,apply()接收两个参数,一个是函数运行的作用域(this),另一个是参数数组。
call()方法第一个参数与apply()方法相同,但传递给函数的参数必须列举出来。 


    var obj1 = {name:"by"};
	var obj2 = {name:"zy"};
	function say(){
		alert(this.name);
	}
	say.call(obj2);//by
	say.apply(obj2);//zy
	
	//传递参数
	function say2(num1,num2){
		alert(this.name+","+(num1+num2));
	}
	say2.call(obj2,10,20);//by,30
	say2.apply(obj2,[10,20]);//zy,30



javascript all,call区别与用法

标签:javascript   function   

原文地址:http://bysowhat.blog.51cto.com/4478944/1575510

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