理解javascript中的Function.prototype.bind的方法
发布时间 - 2026-01-10 22:49:27 点击率:次在初学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中的 “&” 和 “|” 详解
# 很多人
# 象中
# 就可以
# 当我们
# 所示
# 绑定
# 都是
# 一个函数
# 就会
# 使用了
# 尤其是
# 最多
# 不需要
# 才会
# 见过
# 当你
# 我们可以
# 可以通过
# 几种
# 解决问题
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
非常酷的网站设计制作软件,酷培ai教育官方网站?
MySQL查询结果复制到新表的方法(更新、插入)
html5如何实现懒加载图片_ intersectionobserver api用法【教程】
网站制作免费,什么网站能看正片电影?
Win11关机界面怎么改_Win11自定义关机画面设置【工具】
JavaScript如何实现错误处理_try...catch如何捕获异常?
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
如何将凡科建站内容保存为本地文件?
LinuxCD持续部署教程_自动发布与回滚机制
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
Laravel storage目录权限问题_Laravel文件写入权限设置
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
Swift开发中switch语句值绑定模式
Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤
Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案
阿里云网站搭建费用解析:服务器价格与建站成本优化指南
Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用
Python企业级消息系统教程_KafkaRabbitMQ高并发应用
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
PHP 实现电台节目表的智能时间匹配与今日/明日轮播逻辑
C语言设计一个闪闪的圣诞树
如何在阿里云香港服务器快速搭建网站?
零服务器AI建站解决方案:快速部署与云端平台低成本实践
node.js报错:Cannot find module 'ejs'的解决办法
Laravel安装步骤详细教程_Laravel环境搭建指南
如何在宝塔面板中创建新站点?
Firefox Developer Edition开发者版本入口
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决
Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】
Python进程池调度策略_任务分发说明【指导】
如何快速搭建高效香港服务器网站?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何有效防御Web建站篡改攻击?
javascript基于原型链的继承及call和apply函数用法分析
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
如何在橙子建站中快速调整背景颜色?
BootStrap整体框架之基础布局组件
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
网站制作大概多少钱一个,做一个平台网站大概多少钱?

