在JavaScript中正确引用bind方法的应用
作者:bea
在JavaScript中,方法往往涉及到上下文,也就是this,因此往往不能直接引用,就拿最常见的console.log("info…")来说,避免书写冗长的console,直接用log("info…")代替,不假思索的会想到如下语法: var log = console.log; log("info…"); 很遗憾,运行报错:TypeError: Illegal invocation。 为啥呢?对于console.log("info…")而言,log方法在con
在JavaScript中,方法往往涉及到上下文,也就是this,因此往往不能直接引用,就拿最常见的console.log("info…")来说,避免书写冗长的console,直接用log("info…")代替,不假思索的会想到如下语法:
var log = console.log;
log("info…");
很遗憾,运行报错:TypeError: Illegal invocation。
为啥呢?对于console.log("info…")而言,log方法在console对象上调用,因此log方法中的this指向console对象;而我们用log变量指向console.log方法,然后直接调用log方法,此时log方法的this指向的是window对象,上下文不一致,当然会报错了。
此时我们可以用bind方法解决这个问题。bind方法允许手动传入一个this,作为当前方法的上下文,然后返回持有上下文的方法,例如:
var log = console.log.bind(console);
log("info...");
这样就不会报错了。
但是,bind方法并不支持ie 8以及更低版本的浏览器,我们完全可以自己实现一个,很简单。
Function.prototype.bind = Function.prototype.bind || function(context){
var _this = this;
return function(){
_this.apply(context, arguments);
};
};
核心通过apply方法实现,闭包的经典应用。_this指向当前方法,context指向当前方法的上下文,二者均通过闭包访问。
以上所述就是本文的全部内容了,希望大家能够喜欢。
猜你喜欢
您可能感兴趣的文章:
- js/jquery判断浏览器类型的方法小结
- js实现div层缓慢收缩与展开的方法
- JS实现定时自动关闭DIV层提示框的方法
- 最精简的JavaScript实现鼠标拖动效果的方法
- JavaScript实现表格点击排序的方法
- JavaScript点击按钮后弹出透明浮动层的方法
- js实现鼠标移到链接文字弹出一个提示层的方法
- js光标定位文本框回车表单提交问题的解决方法
- jQuery子窗体取得父窗体元素的方法
- js控制div弹出层实现方法
- JavaScript实现点击文字切换登录窗口的方法
- jQuery实现仿腾讯微博滑出效果报告每日天气的方法
- JS选项卡动态替换banner图片路径的方法
- js操作css属性实现div层展开关闭效果的方法
- javascript中this的四种用法
- JQuery插件jcarousellite的参数中文说明
- javascript实现炫酷的拖动分页
- JS+CSS实现的拖动分页效果实例
- 浅谈jQuery构造函数分析