js中call()⽅法的⽤法
1.call⽅法
语法:call(thisobj,[argq,arg2])
定义:调⽤⼀个对象的⼀个⽅法,以另⼀个对象替换当前对象
说明:
call⽅法可以⽤来代替⼀个对象调⽤⼀个⽅法,call⽅法可以将⼀个函数的对象上下⽂从初始化改为新的对象,也就是括号⾥⾯的原本的对象改为call()前⾯的对象、即⽤thisobj代替call前⾯的东西,最终⽤thisobj这个对象去执⾏call前⾯的⽅法。
如果没有提供 thisObj 参数,那么 Global 对象被⽤作 thisObj。
⼀如
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>js中call⽅法的使⽤</title>
</head>
<body>js arguments
<p id="id1">新年</p>
</body>
</html>
<script>
function add(a,b){
alert(a+b);
}
function sub(a,b){
alert(a-b);
}
add.call(sub,3,1);
}
</script>
add代替sub ,最总结过输出
这个例⼦中的意思就是⽤ add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运⾏结果为:alert(4); // 注意:js 中的函数其实是对象,函数名是对 Function 对象的引⽤。
2.apply⽅法
语法:apply(thisobj,[argArray])
定义:应⽤某⼀个对象的⼀个⽅法,⽤别另⼀个对象替换当前对象
说明:
如果 argArray 不是⼀个有效的数组或者不是 arguments 对象,那么将导致⼀个 TypeError。
如果没有提供 argArray 和 thisObj 任何⼀个参数,那么 Global 对象将被⽤作 thisObj, 并且⽆法被传递任何参数。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>js中call⽅法的使⽤</title>
</head>
<body>
<p id="id1">新年</p>
</body>
</html>
<script>
function Animal(){
this.name = "Animal";
this.showName=function(){
alert(this.name);
}
}
function Cat(){
this.name = "Cat";
}
var animal = new Animal();
var cat = new Cat();
// 通过call或apply⽅法,将原本属于Animal对象的showName⽅法交给对象call来使⽤了
animal.showName.apply(cat,[]);
animal.showName.call(cat,",");
}
</script>
注意apply的参数和call⽅法的参数是不同的,apply是⼀个数组
3.call实现js的继承
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论