原文章发表在 Klay-Clam的个人博客
一、细节
- javascript 中函数存在“定义时上下文”,“运行时上下文”
- 上下文是可变的
1. call()
call()
,为改变某个函数运行时的上下文(context)而存在的,换句话说,是为了改变函数内部的this
指向.
// 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()方法
2.apply()
apply()
与call()
作用没有区别,用法与call()方法稍有区别,就是call()的第二个参数(调用函数使用的参数),是一个一个传入的;
而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
3.bind()
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));
}
};
}
二、总结
利用上面的call()
,apply()
和bind()
方法,可以在代码复用减少代码的冗余上面有很大的帮助,以前编码的过程中,的确是没有很好的利用,希望在今后的编码的过程中自己可以努力的去尝试,去试错。
enjoy~
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。