JavaScript---this
2015-10-03 21:51
489 查看
var x="全局对象"; var test={ tests:function test1(){ this.x="外部函数"; function test2(){ alert(this.x);//此时的this指向的是全局对象,本来应该指向的是外部函数对象 }; test2(); } }; test.tests();//结果为"全局对象",这是语言设计上的失误,用的时候需要注意
解决方法:
var x="全局对象"; var test={ tests:function test1(){ this.x="外部函数对象"; var that=this;//通过定义that变量,并赋值为this function test2(){ alert(that.x);//此时内部函数就可以通过that变量来访问外部函数中的x了 }; test2(); } }; test.tests();//结果为"外部函数对象"
更多的this内容可以看这篇文章:
深入理解JavaScript中的this关键字
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- IE8开发人员工具教程(二)
- 在flex中执行一个javascript方法的简单方式
- Flex结合JavaScript读取本地路径的方法
- PowerShell中执行Javascript的方法示例
- javascript asp教程第六课-- response方法
- javascript asp教程More About Recordsets
- javascript asp教程第十二课---session对象