JavaScript 中 call()、apply()、bind() 的用法

通过 call() 或 apply() 方法你可以设置 this 的值, 且作为已存在对象的新方法调用。

call() 和 apply() 是预定义的函数方法。 两个方法可用于调用函数,两个方法的第一个参数必须是对象本身。

两个方法都使用了对象本身作为第一个参数。 两者的区别在于第二个参数: apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。

<!DOCTYPE html>
<html>
<body>

<p id="demo"></p>

<script>
var myObject, myArray;
function myFunction(a, b) {
    return a * b;
}
myArray = [10, 2]
myObject = myFunction.apply(myObject, myArray);      // 返回 20
document.getElementById("demo").innerHTML = myObject; 
</script>

</body>
</html>

<!DOCTYPE html>
<html>
<body>

<p id="demo"></p>

<script>
var myObject;
function myFunction(a, b) {
return a * b;
}
myObject = myFunction.call(myObject, 10, 2); // 返回 20
document.getElementById("demo").innerHTML = myObject;
</script>

</body>
</html>

JavaScript 中 call()、apply()、bind() 的用法

上一篇:【RL-TCPnet网络教程】第26章 RL-TCPnet之DHCP应用


下一篇:如何将 Cortana 与 Windows Phone 8.1 应用集成 ( Voice command - Natural language recognition )