1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 |
|
此时加入bind
复制代码 代码如下:
var text = document.getElementById("text");
var button = document.getElementById("button");
button.onclick = function() {
alert(this.id); // 弹出button
}.bind(text);
//可以看出上下文的this 为button
此时会发现this改变为text
函数字面量里也适用,目的是保持上下指向(this)不变。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
此时点击按钮text里的字会变色。可见this不为button而是obj。
bind()的方法在ie,6,7,8中不适用,需要扩展通过扩展Function prototype可以实现此方法。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
此时可以看到ie6,7,8中也支持bind()。
复制代码 代码如下:
slice = Array.prototype.slice,
或
array = Array.prototype.slice.call( array, 0 );
将类似数组转换为数组