原文章发表在 Klay-Clam的我的博客javascript
- javascript 中函数存在“定义时上下文”,“运行时上下文”
- 上下文是可变的
call()
call()
,为改变某个函数运行时的上下文(context)而存在的,换句话说,是为了改变函数内部的this
指向.java
// demo1 var sayKlay = { name :"Klay", say : function(){ console.log(this.name); } } var sayClam = { name : 'Clam' } /* sayClam()没有say方法,可是sayKlay()有呀 因此能够去把sayKlay.say()方法的运行时上下文 也就是运行时的this的指向,指向sayClam() 这个时候低啊用say()方法就能够sayClam了。 */ sayKlay.say.call(sayClam); // Clam // demo2 function a(xx) { this.b = xx; } var o = {}; a.call(o, 5); console.log(a.b); // undefined console.log(o.b); // 5
参考:MDN call()方法git
apply()
与call()
做用没有区别,用法与call()方法稍有区别,就是call()的第二个参数(调用函数使用的参数),是一个一个传入的;github
而apply()的第二个参数的值是使用数组的形式传入的数组
function add(a,b) { this.sum = a + b; } var o = {}; add.call(o, 5,5); console.log(o.sum); // 10 add.apply(o,[3,5]); console.log(o.sum); // 8
参考 MDN apply()方法app
bind()的做用其实与call()以及apply()都是同样的,都是为了改变函数运行时的上下文,bind()与后面二者的区别是,call()和apply()在调用函数以后会当即执行,而bind()方法调用并改变函数运行时的上下文的以后,返回一个新的函数,在咱们须要调用的地方去调用他。函数
// bind()方法并不会直接调用,只是改变了函数的上下文,并成为一个副本 var button = document.getElementById("button"), text = document.getElementById("text"); button.onclick = function() { alert(this.id); // 弹出text }.bind(text); // ie6-ie8不支持bind()方法,因此要用下面的方法去模拟bind() if (!function() {}.bind) { Function.prototype.bind = function(context) { var self = this , args = Array.prototype.slice.call(arguments); return function() { return self.apply(context, args.slice(1)); } }; }
参考MDN bind()方法this
利用上面的call()
,apply()
和bind()
方法,能够在代码复用减小代码的冗余上面有很大的帮助,之前编码的过程当中,的确是没有很好的利用,但愿在从此的编码的过程当中本身能够努力的去尝试,去试错。编码
enjoy~prototype