js绑定事件this指向发生改变的问题解决方法


Posted in Javascript onApril 23, 2013

可对函数进行如下扩展

Function.prototype.bind = function(obj) { 
var _this = this; 
return function() { 
_this.apply(obj,arguments); 
} 
}

用法如下
var a = function(){ 
alert(this.title) 
}.bind(document); 
a();

常用在这儿
function myalert() { 
this.title = 'hello world'; 
this.init = function() { 
$("#xxx").click(this.close.bind(this)); 
} 
this.close = function() { 
alert(this.title) 
} 
}

<P style="PADDING-BOTTOM: 0px; LINE-HEIGHT: 22px; MARGIN-TOP: 0px; FONT-FAMILY: 微软雅黑, 宋体, 'Trebuchet MS', Tahoma, Arial, sans-serif; MARGIN-BOTTOM: 10px; COLOR: rgb(34,34,34); FONT-SIZE: 14px; PADDING-TOP: 0px" class=p1>var a  = new myalert();</P><P style="PADDING-BOTTOM: 0px; LINE-HEIGHT: 22px; MARGIN-TOP: 0px; FONT-FAMILY: 微软雅黑, 宋体, 'Trebuchet MS', Tahoma, Arial, sans-serif; MARGIN-BOTTOM: 10px; COLOR: rgb(34,34,34); FONT-SIZE: 14px; PADDING-TOP: 0px" class=p1>a.init();</P>
Javascript 相关文章推荐
js 实现复制到粘贴板的功能代码
May 13 Javascript
js中parseInt函数浅谈
Jul 31 Javascript
Javascript的setTimeout()使用闭包特性时需要注意的问题
Sep 23 Javascript
javascript之Array 数组对象详解
Jun 07 Javascript
jQuery实现的tab标签切换效果示例
Sep 05 Javascript
JavaScript遍历Json串浏览器输出的结果不统一问题
Nov 03 Javascript
Vue.js实现表格动态增加删除的方法(附源码下载)
Jan 20 Javascript
微信小程序request请求后台接口php的实例详解
Sep 20 Javascript
讲解vue-router之什么是嵌套路由
May 28 Javascript
swiper.js插件实现pc端文本上下滑动功能示例
Dec 03 Javascript
JavaScript和TypeScript中的void的具体使用
Sep 12 Javascript
JavaScript进制转换实现方法解析
Jan 18 Javascript
js判断生效时间不得大于失效时间的思路及代码
Apr 23 #Javascript
修改file按钮的默认样式实现代码
Apr 23 #Javascript
js随机颜色代码的多种实现方式
Apr 23 #Javascript
js对象与打印对象分析比较
Apr 23 #Javascript
你必须知道的Javascript知识点之&quot;深入理解作用域链&quot;的介绍
Apr 23 #Javascript
你必须知道的Javascript知识点之&quot;字面量和对应类型&quot;说明介绍
Apr 23 #Javascript
你必须知道的Javascript知识点之&quot;单线程事件驱动&quot;的使用
Apr 23 #Javascript
You might like
如何用phpmyadmin设置mysql数据库用户的权限
2012/01/09 PHP
PHP框架Laravel学习心得体会
2015/10/28 PHP
jQuery EasyUI API 中文文档 - MenuButton菜单按钮使用介绍
2011/10/06 Javascript
使用javascript创建快捷方式的简单实例
2013/08/09 Javascript
使用js对select动态添加和删除OPTION示例代码
2013/08/12 Javascript
JS+DIV实现鼠标划过切换层效果的方法
2015/05/25 Javascript
JS实现当前页居中分页效果的方法
2015/06/18 Javascript
jQuery插件formValidator自定义函数扩展功能实例详解
2015/11/25 Javascript
基于javascript实现浏览器滚动条快到底部时自动加载数据
2015/11/30 Javascript
JavaScript中获取时间的函数集
2016/08/16 Javascript
AngularJS入门教程之更多模板详解
2016/08/19 Javascript
vue分类筛选filter方法简单实例
2017/03/30 Javascript
jQuery选择器特殊字符与属性空格问题
2017/08/14 jQuery
使用JS和canvas实现gif动图的停止和播放代码
2017/09/01 Javascript
5分钟学会Vue动画效果(小结)
2018/07/21 Javascript
BootStrap table实现表格行拖拽效果
2018/12/01 Javascript
Vue Router history模式的配置方法及其原理
2019/05/30 Javascript
解决layui调用自定义方法提示未定义的问题
2019/09/14 Javascript
阿望教你用vue写扫雷小游戏
2020/01/20 Javascript
Javascript组合继承方法代码实例解析
2020/04/02 Javascript
[01:10:58]Spirit vs NB Supermajor小组赛 A组败者组决赛 BO3 第二场 6.2
2018/06/03 DOTA
让 python 命令行也可以自动补全
2014/11/30 Python
python使用xmlrpclib模块实现对百度google的ping功能
2015/06/02 Python
Python脚本暴力破解栅栏密码
2015/10/19 Python
python下载文件记录黑名单的实现代码
2017/10/24 Python
Python3实现转换Image图片格式
2018/06/21 Python
基于python绘制科赫雪花
2018/06/22 Python
Python实现的逻辑回归算法示例【附测试csv文件下载】
2018/12/28 Python
PyQt5固定窗口大小的方法
2019/06/18 Python
Python3打包exe代码2种方法实例解析
2020/02/17 Python
通过实例了解Python异常处理机制底层实现
2020/07/23 Python
巴西在线鞋店:Shoestock
2017/10/28 全球购物
2014感恩节演讲稿大全
2014/10/11 职场文书
贫困证明书格式及范文
2014/10/15 职场文书
党的群众路线教育实践活动心得体会(企业)
2014/11/03 职场文书
健康证明
2015/06/19 职场文书