js的call比apply性能好

本文探讨了JavaScript中this指向的概念,通过实例演示了apply和call如何改变函数内部的this指向,并进行了两者之间的性能对比测试。实验结果显示,在参数数量较少时两者性能相近,但参数超过三个时call表现更优。
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<script>
			//apply和call都可以改变this的指向,返回值就是函数的返回值
			
			//apply和call是f1的构造函数的原型里的(也就是Function的原型对象里的)
			
			//参数在三个以及以内都一样,超过三个call的性能要好一些
			
			//自己实现性能测试(只供参考):任何的代码测试都是和测试环境有关,例如CPU,内存等
			console.time("A")
			
			console.dir(Function)
			function f1(x,y){
				console.log(x+y,this)
				return "return"
			}
			
			var obj = {
				sex:"男"
			}
			
			var r2 = f1.call(obj,1,2)
			var r1 = f1.apply(obj,[1,2])
			
			console.log(r1,r2)
			console.timeEnd("A")
		</script>
	</body>
</html>

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值