当前位置:首页 > 日记 > 正文

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

理解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(); // undefinedvar boundFunc = bar.bind(foo);boundFunc(); // 3

下面的例子也是常见的:

this.x = 9;  // this refers to global "window" object here in the browservar module = { x: 81, getX: function() { return this.x; }};module.getX(); // 81var 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 xvar 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; };}

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

相关文章

深入浅析Orcale的nvl函数和SQL Ser

深入浅析Orcale的nvl函数和SQL Ser

函数,电脑软件,nvl,Orcale,isnull,Orcal 的 nvl函数NVL(Expr1,Expr2)如果Expr1为NULL,返回Expr2的值,否则返回Expr1的值,Expr1,Expr2都为NULL则返回NULLNVL2(Expr1,Expr2,Expr3)如果Expr1为NULL,返回Expr2的值,否则返回Expr3的值NULLIF(Expr1,Ex…

excel2007插入公式编辑器的方法exc

excel2007插入公式编辑器的方法exc

公式编辑器,方法,电脑软件,strong,  Excel中经常需要使用到公式编辑器编辑公式,公式编辑器具体该如何插入呢?接下来是小编为大家带来的excel2007插入公式编辑器的方法,供大家参考。excel2007插入公式编辑器的方法插入公式编辑器步骤1:打开Ex…

通过IIS设置架设FTP服务器程序步骤

通过IIS设置架设FTP服务器程序步骤

设置,步骤,服务器,程序,电脑软件, FTP服务器在文件的传输上性能稳定,占用系统资源小,而且传输速度快,现在网上已经有很多的FTP服务器可供使用,而微软IIS强大的功能,除了提供WWW服务之外,还提供FTP的服务,利用它就可以很容易架设一个功能卓越的F…

如何设置Excel2013单元格被修改时

如何设置Excel2013单元格被修改时

设置,修改,输入,密码修改,单元格,  在保护工作表时,为工作表设置多个可以修改的区域,并为每个单元格区域设置一个修改密码,防止不小心或恶意的破坏,有效降低风险。以下是小编为您带来的关于设置Excel2013单元格被修改时需要输入密码,希望对您…

php数据序列化测试实例详解

php数据序列化测试实例详解

数据,序列化,详解,实例,测试,php数据序列化测试实例详解测试代码$msg = ['test'=>23];$start = microtime(true); for($i=0;$i<100000;$i++){ $packMsg = msgpack_pack($msg);}echo 'pack len:'.strlen($packMsg)."\r\n";$end = m…

技巧:打造灵活安全的存储域服务器

技巧:打造灵活安全的存储域服务器

服务器,灵活,技巧,电脑软件,计算机的发展很快,国内大部分中小型企业都采购有服务器。在中小型企业服务器应用当中,笔者接触最多的两种应用是:企业内部文件交换与存储的文件服务器、内部安全控制管理的域控制服务器。如何对企业文件存储服务器…

ps给书本制作逼真的倒影效果

ps给书本制作逼真的倒影效果

倒影,逼真,书本,效果,电脑软件,这篇教程是向的朋友分享ps给书本制作逼真的倒影效果方法,小编使用是PS CS6软件,使用别的版本也可以做出来的,软件里的功能基本上还是一样的,所以大家不用担心,好了,下面我们来学习吧。步骤:1、打开PS软件,在软件界面…

JavaScript中三个等号和两个等号你

JavaScript中三个等号和两个等号你

等号,两个,电脑软件,JavaScript,引子众所周知,用在if条件判断语句中,js有六种假值:false, null, undefined, '', NAN, 0。先来看几个例子:[] === []NaN === NaNNaN == NaN0 == []'' == []'' == {}[] == undefined{} == []null == undefin…

PS线稿上色小过程解析

PS线稿上色小过程解析

过程,电脑软件,PS,   今天小编分享的是一个线稿上色的小过程,需要手绘板,人设概念,一定的美术功底(起码明白光影明暗),必要的脑补能力。一起来看看吧!PS线稿上色的方法技巧我们的效果图观察线稿,然后确定光源方向,脑补人设原型。把线…

PHP编辑器PhpStrom运行缓慢问题

PHP编辑器PhpStrom运行缓慢问题

运行,编辑器,缓慢,电脑软件,PHP,最近在使用phpstorm开发项目的时候,在加载文件运行时,不管有多大,如果项目文件数据比较多的话,都能够让phpstorm卡到死机。其中调整过内存设置,关闭过动态提示,使用过phpstorm的安全模式,都不能解决卡的问题。中间…

ps实例讲解智能对象对模型的妙用

ps实例讲解智能对象对模型的妙用

模型,智能,对象,妙用,实例,版权申明:本文原创作者"孙圣朝",感谢"孙圣朝"的原创经验分享!PS智能对象是把位图和矢量图完美结合的桥梁。在设计工作中,我们合理的利用PS智能对象来处理我们设计的模型,或者是样机能在很大程度上提升我们的工作效…

jQuery 实现双击编辑表格功能

jQuery 实现双击编辑表格功能

双击,表格,编辑,功能,电脑软件,先给大家展示下效果图:下面用简单方法实现的简单表格编辑功能:简单的HTML代码略过了,下面是js实现过程JavaScript:<span style="font-size:18px;">$(".tables").on("dblclick","td",function(){ if($…