源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

javascript如何使用bind指定接收者

  • 时间:2021-01-04 02:31 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:javascript如何使用bind指定接收者
[u]复制代码[/u] 代码如下:
var json = { jArray: [], jPush: function (c) { this.jArray.push(c); } } var examp = ["123", "~", "456"];
使用ES5给出的forEach循环examp,并且将它们添加到json中的jArray中;
[u]复制代码[/u] 代码如下:
examp.forEach(json.jPush);
这个时候会报错: [img]http://files.jb51.net/file_images/article/201405/20140504172057.png?201444172134[/img]   产生这种报错的原因是json.jPush方法中的this并没有指向json对象,而是指向了window.解决这个问题的方法就是给这个this找对人家. 好在forEach()提供了一个参数,专门用于指定对象的.看代码.
[u]复制代码[/u] 代码如下:
examp.forEach(json.jPush,json); alert(json.jArray);//结果正常了是,123~456
还有另外一种方法:
[u]复制代码[/u] 代码如下:
examp.forEach(function (c) { json.jPush(c); }); alert(json.jArray);//123~456
还可以使用bind绑定
[u]复制代码[/u] 代码如下:
examp.forEach(json.jPush.bind(json)); alert(json.jArray);
bind是创建了一个新函数而不是修改一个函数.新函数的行为和原来函数的行为一样,但他的接收者是我们给定的对象,而原有函数的接收者保持不变. 这意味着bind方法的使用是非常安全的,因为一个函数或方法被共享的时候,不用担心这个共享方法不会被修改掉了.
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部