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 相关文章推荐
jquery multiSelect 多选下拉框
Jul 09 Javascript
javascript开发技术大全-第3章 js数据类型
Jul 03 Javascript
javascript定时器完整实例
Feb 10 Javascript
JS实现网页上随机产生超链接地址的方法
Nov 09 Javascript
图解prototype、proto和constructor的三角关系
Jul 31 Javascript
JavaScript仿微博发布信息案例
Nov 16 Javascript
JavaScript 网页中实现一个计算当年还剩多少时间的倒数计时程序
Jan 25 Javascript
js实现登录框鼠标拖拽效果
Mar 09 Javascript
jQuery EasyUI开发技巧总结
Sep 26 jQuery
详解如何理解vue的key属性
Apr 14 Javascript
详解vue2.0模拟后台json数据
May 16 Javascript
Vue项目中如何使用Axios封装http请求详解
Oct 23 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
php中文本数据翻页(留言本翻页)
2006/10/09 PHP
php加密算法之实现可逆加密算法和解密分享
2014/01/21 PHP
PHP制作万年历
2015/01/07 PHP
PHP递归调用数组值并用其执行指定函数的方法
2015/04/01 PHP
jQuery 剧场版 你必须知道的javascript
2009/05/27 Javascript
JQuery 插件模板 制作jquery插件的朋友可以参考下
2010/03/17 Javascript
js加入收藏以及使用Jquery更改透明度
2014/01/26 Javascript
JQuery插入DOM节点的方法
2015/06/11 Javascript
jquery实现向下滑出的二级导航下滑菜单效果
2015/08/25 Javascript
浅谈js对象属性 通过点(.) 和方括号([]) 的不同之处
2016/10/29 Javascript
js 转json格式的字符串为对象或数组(前后台)的方法
2016/11/02 Javascript
javascript回调函数的概念理解与用法分析
2017/05/27 Javascript
一次围绕setTimeout的前端面试经验分享
2017/06/15 Javascript
关于vue.extend和vue.component的区别浅析
2017/08/16 Javascript
vue组件初学_弹射小球(实例讲解)
2017/09/06 Javascript
JS引用传递与值传递的区别与用法分析
2018/06/01 Javascript
JavaScript 截取字符串代码实例
2019/09/05 Javascript
原生JS与JQ获取元素的区别详解
2020/02/13 Javascript
[02:52]2014DOTA2西雅图国际邀请赛 CIS战队巡礼
2014/07/07 DOTA
[01:09]2014DOTA2国际邀请赛 TI4西雅图DOTA2 中国美女coser加油助威
2014/07/20 DOTA
使用Python获取CPU、内存和硬盘等windowns系统信息的2个例子
2014/04/15 Python
Python类方法__init__和__del__构造、析构过程分析
2015/03/06 Python
python获取一组汉字拼音首字母的方法
2015/07/01 Python
python使用标准库根据进程名如何获取进程的pid详解
2017/10/31 Python
python实现百度语音识别api
2018/04/10 Python
django_orm查询性能优化方法
2018/08/20 Python
python实现贪吃蛇小游戏
2020/03/21 Python
Python Scrapy框架第一个入门程序示例
2020/02/05 Python
python gui开发——制作抖音无水印视频下载工具(附源码)
2021/02/07 Python
CSS3 :not()选择器实现最后一行li去除某种css样式
2016/10/19 HTML / CSS
工人先锋号事迹材料
2014/12/24 职场文书
公司出差管理制度范本
2015/08/05 职场文书
幼儿园大班教学反思
2016/03/02 职场文书
一封真诚的自荐信帮你赢得机会
2019/05/07 职场文书
PostgreSQL将数据加载到buffer cache中操作方法
2021/04/16 PostgreSQL
Python编程中内置的NotImplemented类型的用法
2022/03/23 Python