全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

理解javascript中的Function.prototype.bind的方法

在初学Javascript时,我们也许不需要担心函数绑定的问题,但是当我们需要在另一个函数中保持上下文对象this时,就会遇到相应的问题了,我见过很多人处理这种问题都是先将this赋值给一个变量(比如self、_this、that等),尤其是var that = this是我见的最多的,这样当你改变环境之后就可以使用它。这些都是可以的,但是还有一种更好的、更专有的方法,那就是使用Function.prototype.bind,下面进行详尽的讲解。  

第一部分:需要解决的问题

首先看下面的代码

var myObj = {

  specialFunction: function () {

  },

  anotherSpecialFunction: function () {

  },

  getAsyncData: function (cb) {
    cb();
  },

  render: function () {
this.getAsyncData(function () {
      this.specialFunction();
      this.anotherSpecialFunction();
    });
  }
};

myObj.render();

这里我希望创建一个对象,包含了前面两个普通的方法;第三个方法可以传递一个函数,传入的这个函数立即执行;最后一个方法会调用myObj对象的getAsyncData方法,这里使用了this,然后在getAsyncData方法中传入了一个函数,这个函数继续调用这个对象的前两个方法,仍使用了this,这时很多人实际上就可以看出问题所在了,将上述代码输入控制台,得到下面的结果:

TypeError: this.specialFunction is not a function

第二部分:问题剖析

在对象中render方法中的this的确是指向myObj对象的,所以我们可以通过this.getAsyncData来调用这个对象中的函数,但是当我们给其传递函数作为参数时,这里的this就指向了全局环境window了,因为全局环境中没有对象中的前两个方法,所以才会报错。

第三部分:解决问题的几种方式

所以我们需要做的就是正确调用对象中的前两个方法 ,很多人使用的方法便是首先在对象的环境中获取this赋值给另一个变量,这时就可以在后面的环境中调用了,如下所示:

  render: function () {
    var that = this;
    this.getAsyncData(function () {
      that.specialFunction();
      that.anotherSpecialFunction();
    });
  }  

虽然这种方法是可行的,但是使用Function.prototype.bind()会使代码更清晰、易懂,如下所示:

render: function () {

  this.getAsyncData(function () {

    this.specialFunction();

    this.anotherSpecialFunction();

  }.bind(this));

}

这里我们就成功地把this绑定到了环境中。

下面是另外一个简单的例子:

var foo = {
  x: 3
}

var bar = function(){
  console.log(this.x);
}

bar(); // undefined

var boundFunc = bar.bind(foo);

boundFunc(); // 3

下面的例子也是常见的:

this.x = 9;  // this refers to global "window" object here in the browser
var module = {
 x: 81,
 getX: function() { return this.x; }
};

module.getX(); // 81

var retrieveX = module.getX;
retrieveX();  
// returns 9 - The function gets invoked at the global scope

// Create a new function with 'this' bound to module
// New programmers might confuse the
// global var x with module's property x
var boundGetX = retrieveX.bind(module);
boundGetX(); // 81

第四部分:浏览器支持

但是这个方法在IE8及以下是不被支持的,所以我们可以使用MDN提供的方法来使得IE低版本支持.bind()方法:

if (!Function.prototype.bind) {
 Function.prototype.bind = function (oThis) {
  if (typeof this !== "function") {
   // closest thing possible to the ECMAScript 5 internal IsCallable function
   throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");
  }

  var aArgs = Array.prototype.slice.call(arguments, 1),
    fToBind = this,
    fNOP = function () {},
    fBound = function () {
     return fToBind.apply(this instanceof fNOP && oThis
                 ? this
                 : oThis,
                aArgs.concat(Array.prototype.slice.call(arguments)));
    };

  fNOP.prototype = this.prototype;
  fBound.prototype = new fNOP();

  return fBound;
 };
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Function.prototype.bind  # Javascript中数组去重与拍平的方法示例  # JavaScript数组复制详解  # Javascript基础回顾之(三) js面向对象  # Javascript基础回顾之(一) 类型  # JavaScript基础之AJAX简单的小demo  # JavaScript Date 知识浅析  # JavaScript实现时钟滴答声效果  # Javascript中 带名 匿名 箭头函数的重要区别(推荐)  # javascript判断回文数详解及实现代码  # 浅谈javascript中的 “ && ” 和 “ || ”  # Javascript中的 “&” 和 “|” 详解  # 很多人  # 象中  # 就可以  # 当我们  # 所示  # 绑定  # 都是  # 一个函数  # 就会  # 使用了  # 尤其是  # 最多  # 不需要  # 才会  # 见过  # 当你  # 我们可以  # 可以通过  # 几种  # 解决问题 


相关文章: 网站视频怎么制作,哪个网站可以免费收看好莱坞经典大片?  建站主机选哪家性价比最高?  官网自助建站平台指南:在线制作、快速建站与模板选择全解析  jQuery 常见小例汇总  中山网站推广排名,中山信息港登录入口?  如何在香港免费服务器上快速搭建网站?  如何将凡科建站内容保存为本地文件?  c++ stringstream用法详解_c++字符串与数字转换利器  建站之星2.7模板:企业网站建设与h5定制设计专题  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  网站制作公司排行榜,四大门户网站排名?  学校为何禁止电信移动建设网站?  如何通过老薛主机一键快速建站?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  商务网站制作工程师,从哪几个方面把握电子商务网站主页和页面的特色设计?  高防服务器:AI智能防御DDoS攻击与数据安全保障  建站之星导航如何优化提升用户体验?  专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?  黑客入侵网站服务器的常见手法有哪些?  临沂网站制作企业,临沂第三中学官方网站?  定制建站策划方案_专业建站与网站建设方案一站式指南  如何通过VPS建站实现广告与增值服务盈利?  已有域名如何免费搭建网站?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  制作网站的过程怎么写,用凡科建站如何制作自己的网站?  ,制作一个手机app网站要多少钱?  制作网站怎么制作,*游戏网站怎么搭建?  建站之星后台密码遗忘或太弱?如何重置与强化?  如何通过虚拟主机快速完成网站搭建?  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  家庭服务器如何搭建个人网站?  智能起名网站制作软件有哪些,制作logo的软件?  如何高效利用200m空间完成建站?  如何在云主机快速搭建网站站点?  建站之星好吗?新手能否轻松上手建站?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  岳西云建站教程与模板下载_一站式快速建站系统操作指南  建站之星后台密码如何安全设置与找回?  建站OpenVZ教程与优化策略:配置指南与性能提升  seo网站制作优化,网站SEO优化步骤有哪些?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  网站制作的步骤包括,正确网址格式怎么写?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  表情包在线制作网站免费,表情包怎么弄?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  小型网站建站如何选择虚拟主机?  建站主机功能解析:服务器选择与快速搭建指南  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何选择最佳自助建站系统?快速指南解析优劣  如何快速查询网址的建站时间与历史轨迹? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。