手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >javascript如何使用bind指定接收者
javascript如何使用bind指定接收者
摘要:复制代码代码如下:varjson={jArray:[],jPush:function(c){this.jArray.push(c);}}va...

复制代码 代码如下:

var json = {

jArray: [],

jPush: function (c) {

this.jArray.push(c);

}

}

var examp = ["123", "~", "456"];

使用ES5给出的forEach循环examp,并且将它们添加到json中的jArray中;

复制代码 代码如下:

examp.forEach(json.jPush);

这个时候会报错:

javascript如何使用bind指定接收者1

产生这种报错的原因是json.jPush方法中的this并没有指向json对象,而是指向了window.解决这个问题的方法就是给这个this找对人家.

好在forEach()提供了一个参数,专门用于指定对象的.看代码.

复制代码 代码如下:

examp.forEach(json.jPush,json);

alert(json.jArray);//结果正常了是,123~456

还有另外一种方法:

复制代码 代码如下:

examp.forEach(function (c) {

json.jPush(c);

});

alert(json.jArray);//123~456

还可以使用bind绑定

复制代码 代码如下:

examp.forEach(json.jPush.bind(json));

alert(json.jArray);

bind是创建了一个新函数而不是修改一个函数.新函数的行为和原来函数的行为一样,但他的接收者是我们给定的对象,而原有函数的接收者保持不变.

这意味着bind方法的使用是非常安全的,因为一个函数或方法被共享的时候,不用担心这个共享方法不会被修改掉了.

【javascript如何使用bind指定接收者】相关文章:

JavaScript中length属性的使用方法

javascript常用方法总结

Javascript 高阶函数使用介绍

用javascript动态注释掉HTML代码

JavaScript中使用Math.PI圆周率属性的方法

JavaScript中的acos()方法使用详解

在JavaScript中使用JSON数据

javaScript中with函数用法实例分析

javascript无刷新评论实现方法

javascript中this的四种用法

精品推荐
分类导航