<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>apply-call-bind用法</title>
</head>
<body>
<script>
// apply B.apply(A, arguments);即A对象应用B对象的方法 this指向A
// call B.call(A, args1,args2);即A对象调用B对象的方法 this指向A
// apply和call的功能是一样的,只是传入的参数列表形式不同
// bind 最简单的用法是创建一个函数,使这个函数不论怎么调用都有同样的this值
this.num = 9;
var mymodule = {
num: 81,
getNum: function () { return this.num; }
};
console.log()
mymodule.getNum(); // 81 this指向 mymodule
var getNum = mymodule.getNum;
getNum(); // 9, 因为在这个例子中,"this"指向全局对象
// 创建一个'this'绑定到module的函数
var boundGetNum = getNum.bind(mymodule); // this指向mymodule
boundGetNum(); // 81
</script>
</body>
</html>