javascript之bind使用介绍


Posted in Javascript onOctober 09, 2011

前几天看到一个面试题,题目是这样的:
请你说说对javascript中apply,call,bind的理解?
首先apply和call是老生常谈的东西,但是对于bind,我愣了下,因为这个词是jquery中使用频率很高的一个方法,用来给DOM元素绑定事件用的。
为了搞清这个陌生又熟悉的bind,google一下,发现javascript1.8.5版本中原生实现了此方法,目前IE9+,ff4+,chrome7+支持此方法,opera和safari不支持(MDN上的说明)。
bind的作用和apply,call类似都是改变函数的execute context,也就是runtime时this关键字的指向。但是使用方法略有不同。一个函数进行bind后可稍后执行。
例子如下:

var person = { 
name: 'Andrew', 
job: 'web front end developer', 
gender: 'male', 
sayHello: function() { 
return 'Hi, I am ' + this.name + ', a ' + this.job; 
} 
} 
console.log(person.sayHello()); // Hi, I am Andrew, a web front end developer 
var anotherGuySayHello = person.sayHello.bind({ 
name:'Alex', 
job: 'back end C# developer' 
}); 
console.log(anotherGuySayHello()); // Hi, I am Alex, a back end C# developer

另外带有参数的例子:
function add(arg1, arg2, arg3, arg4) { 
return arg1 + ' ' + arg2 + ' ' + arg3 + ' ' + arg4; 
} 
var addMore = add.bind({}, 'a', 'b'); 
console.log(addMore('c', 'd')); // a b c d

如果你的浏览器暂时不支持此方法,但你又觉得这个很cool,想用,MDN上也给出参考实现, 这个实现很有意思,代码如下:
if(!Function.prototype.bind) { 
Function.prototype.bind = function(oThis) { 
if(typeof this !== 'function') { 
throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable'); 
} 
var fSlice = Array.prototype.slice, 
aArgs = fSlice.call(arguments, 1), 
fToBind = this, 
fNOP = function() {}, 
fBound = function() { 
return fToBind.apply(this instanceof fNOP ? this : oThis || window, aArgs.concat(fSlice.call(arguments))); 
}; 
fNOP.prototype = this.prototype; 
fBound.prototype = new fNOP(); 
return fBound; 
}; 
}

最后几行代码,通过prototype chain的方式,其中fBound是调用bind函数的子类,为什么这么实现,可以仔细看 fBound = function(){ return ... }这一部分,其中this是运行时决定的,这里主要考虑到如果用new的方式来调用函数(构造函数方式)的情况。
下面的例子,就能很好的说明这点,为了方便说明,此例子直接来自MDN:
function Point(x,y) { 
this.x = x; 
this.y = y; 
} 
Point.prototype.toString = function() { 
return this.x + ',' + this.y; 
}; 
var p = new Point(1, 2); 
p.toString(); // 1,2 
var emptyObj = {}; 
var YAxisPoint = Point.bind(emptyObj, 0); 
var axisPoint = new YAxisPoint(5); 
axisPoint.toString(); // 0, 5 
axisPoint instanceof Point; // true 
axisPoint instanceof YAxisPoint; // true

最后给出文章链接,方便您进一步了解
MDN: https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Function/bind

MSDN: http://msdn.microsoft.com/en-us/library/ff841995%28v=vs.94%29.aspx
Javascript 相关文章推荐
JavaScript的parseInt 进制问题
May 07 Javascript
CSS javascript 结合实现悬浮固定菜单效果
Aug 23 Javascript
JQuery validate插件验证用户注册信息
May 11 Javascript
全面解析Bootstrap中scrollspy(滚动监听)的使用方法
Jun 06 Javascript
AngularJS基础 ng-init 指令简单示例
Aug 02 Javascript
原生js仿jquery一些常用方法(必看篇)
Sep 20 Javascript
js利用appendChild对标签进行排序的实现方法
Oct 16 Javascript
js中apply与call简单用法详解
Nov 06 Javascript
微信小程序数字滚动插件使用详解
Feb 02 Javascript
vue iview组件表格 render函数的使用方法详解
Mar 15 Javascript
react 应用多入口配置及实践总结
Oct 17 Javascript
js中async函数结合promise的小案例浅析
Apr 14 Javascript
javascript之querySelector和querySelectorAll使用说明
Oct 09 #Javascript
使用jQuery操作Cookies的实现代码
Oct 09 #Javascript
jQuery实现切换页面布局使用介绍
Oct 09 #Javascript
passwordStrength 基于jquery的密码强度检测代码使用介绍
Oct 08 #Javascript
关于jQuery的inArray 方法介绍
Oct 08 #Javascript
imgAreaSelect 中文文档帮助说明
Oct 08 #Javascript
JavaScript判断一个URL链接是否有效的实现方法
Oct 08 #Javascript
You might like
关于js与php互相传值的介绍
2013/06/25 PHP
初识PHP
2014/09/28 PHP
php将金额数字转化为中文大写
2015/07/09 PHP
PHP7 安装event扩展的实现方法
2019/10/08 PHP
百度 popup.js 完美修正版非常的不错 脚本之家推荐
2009/04/17 Javascript
js兼容的placeholder属性详解
2013/08/18 Javascript
jquery mobile 移动web(5)
2015/12/20 Javascript
JavaScript事件处理的方式(三种)
2016/04/26 Javascript
jQuery之动画效果大全
2016/11/09 Javascript
vue实现点击当前标签高亮效果【推荐】
2018/06/22 Javascript
JavaScript使用indexOf()实现数组去重的方法分析
2018/09/04 Javascript
如何实现一个webpack模块解析器
2018/10/24 Javascript
vue cli3.0 引入eslint 结合vscode使用
2019/05/27 Javascript
用Python登录好友QQ空间点赞的示例代码
2017/11/04 Python
python3监控CentOS磁盘空间脚本
2018/06/21 Python
python_opencv用线段画封闭矩形的实例
2018/12/05 Python
eclipse创建python项目步骤详解
2019/05/10 Python
python有序查找算法 二分法实例解析
2020/02/18 Python
台湾线上百货零售购物平台:friDay购物
2017/08/18 全球购物
德国孕妇装和婴童服装网上商店:bellybutton
2018/04/12 全球购物
Speedo速比涛中国官方网站:全球领先泳装运动品牌
2018/04/24 全球购物
什么是符号链接,什么是硬链接?符号链接与硬链接的区别是什么?
2014/01/19 面试题
建筑人员岗位职责
2013/12/25 职场文书
金融专业大学生自我评价
2014/01/09 职场文书
高中军训感言800字
2014/03/05 职场文书
环保公益广告语
2014/03/13 职场文书
中华在我心中演讲稿
2014/09/13 职场文书
2015年班级元旦晚会活动总结
2014/11/28 职场文书
车间主任岗位职责
2015/02/03 职场文书
个人求职意向书
2015/05/11 职场文书
女性健康知识讲座主持词
2015/07/04 职场文书
赞助商致辞
2015/07/30 职场文书
村党总支部公开承诺书2016
2016/03/25 职场文书
SQL Server中使用判断语句(IF ELSE/CASE WHEN )案例
2021/07/07 SQL Server
Javascript使用integrity属性进行安全验证
2021/11/07 Javascript
Python可视化神器pyecharts之绘制地理图表练习
2022/07/07 Python