实例浅析js的this


Posted in Javascript onDecember 11, 2016

js的this是什么?关于这个东西,博客园里面有太多的解释了,不过,本人看了一下,感觉对this解释的有点复杂了,因此,本人在此给this一个简单易于理解的定义。

this其实是js的一个对象,至于是什么对象呢?很简单,this这个对象就是:谁调用它它就指向谁。

关于这一点,其实,博客园的文章已经说明了很多了,有的文章也说到了点子上,只不过,他们解释的还是有点模糊,这里,我给大家做几个简单的对照实验,根据这几个对照实验的结果,大家应该很清楚了。

希望大家根据我的代码重复实现下面的实验。

首先,我们来看下面的代码:

//创建一个局部对象a
var a = {
 user:'小东',
 getName:function(){
  return this.user;//返回当前对象的user属性值
 }
}
//调用a的getName方法
alert(a.getName());

上面的代码会输出什么呢?没错,这里alert的是····小东····,很简单,这里是在a对象的内部调用this嘛,肯定是a对象调用this,所以根据···········谁调用this它就指向谁这个定义···········,那么这里的this指向的就是a对象。

接下来,我们再给上面的代码添加一行:

//创建一个局部对象a
var a = {
 user:'小东',
 getName:function(){
  return this.user;//返回当前对象的user属性值
 }
}
//调用a的getName方法
alert(a.getName());
//把局部对象的属性函数赋值给外面的变量out
var out = a.getName;
//调用out函数
alert(out());

根据上面的实验结果,我们知道直接调用a.getName输出的是小东,对吧?那么,我们把a.getName这个属性函数赋值给out变量之后,再来调用out会输出什么呢?结果是:undefined的。为什么会是undefined的?请思考一会。要是你明白这里为什么输出的是undefined的原因,那么,我想你对this的理解已经很清楚了。但是,如果,你对本文感兴趣,你还是可以继续看下去的。

这里,我先不解释为什么在外面引用a对象的getName函数却得不到a对象里面的值,我们转过弯来讲,请看下面的代码(其实和上面的代码是差不多的,呵呵):

//创建一个局部对象a
var a = {
 user:'小东',
 getName:function(){
 return 1;//这里我们不返回this,而是返回1
}
}
//调用a的getName方法
alert(a.getName());
//把局部对象的属性函数赋值给外面的变量out
var out = a.getName;
//调用out函数
alert(out());

上面的代码很简单吧,这里,我们不在a对象的getName属性函数里面返回a对象的东西,而是返回···1·····,那么,此刻你再调用out函数,你觉得会输出什么呢?没错,你得到的不再是····undefined····的,而是一个实实在在的数字····1······。这就奇怪了,是吧?当a.getName函数返回的是a对象里面的user属性时,我们用out来引用a.getName函数时,我们得到的是undefined的结果,而当a.getName函数返回的是1时,我们再用out引用a.getName函数却可以得到a.getName里面的东西?这是怎么回事呢?

原因很简单,当我们调用外面的全局变量out的时候,this它指向的应该out的对象,而不是a对象,而out的对象是谁呢?我们应该知道,js在全局中声明的变量的对象是window对象吧。既然调用out时,this指向的是window,那么函数out=a.getName=function(){return this.user;}里面的this.user我们应该写出window.user对吧?但是,此刻,全局变量中有没有一个window.user的属性值呢?没有吧?既然没有window.user这个属性值,那么我们alert(window.user)肯定是undefined啦。为了证明这一点,我们来做下面的实验:

//创建一个局部对象a
var a = {
 user:'小东',
 getName:function(){
  return this.user;//返回当前对象的user属性值
 }
}
//调用a的getName方法
alert(a.getName());
//把局部对象的属性函数赋值给外面的变量out
var out = a.getName;
//我们增加一个window.user的全局属性,看看再次调用out函数会输出什么
var window.user='window"s username';
//调用out函数
alert(out());

此刻,当你再执行上面的代码时,你会发现,out函数输出的不再是undefined,而是window's username,这证明了什么?证明了当out调用this时,this确实指向了window,同时也证明了,this确实是:谁调用它它就指向谁。

如果你不理解js的全局变量,那么,我们可以把上面的代码换成下面的代码再来调用out,你就更加明白了:

//创建一个局部对象a
var a = {
 user:'小东',
 getName:function(){
  return this.user;//返回当前对象的user属性值
 }
}
//调用a的getName方法
alert(a.getName());
//把局部对象的属性函数赋值给外面的变量out
var out = a.getName;
//此刻,我们增加一个user的变量,看看再次调用out函数会输出什么
var user='window"s username';
//调用out函数
alert(out());

这里,我们不再启用window这个对象,对于外面的属性和函数,我们一律都用var 来声明,既然都用var来声明,那么他们应该都指向同一个对象吧?此刻,你再执行上面的代码,也就是执行out函数,依然可以alert出window's username。行文到此,this的定义已经再明白不过了,它就是:谁调用它它就指向谁。

this不难理解,难以理解的是,你要找到那个调用它的········对象·····,只有找到调用this的对象,你才知道this到底指向谁,因为:this的定义就是:谁调用它它就指向谁。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
jquery.validate使用攻略 第三部
Jul 01 Javascript
变量声明时命名与变量作为对象属性时命名的区别解析
Dec 06 Javascript
Javascript单元测试框架QUnitjs详细介绍
May 08 Javascript
javascript实现自动输出文本(打字特效)
Aug 27 Javascript
分享经典的JavaScript开发技巧
Nov 21 Javascript
基于javascript实现动态时钟效果
Aug 18 Javascript
javascript中闭包概念与用法深入理解
Dec 15 Javascript
使用BootStrap实现表格隔行变色及hover变色并在需要时出现滚动条
Jan 04 Javascript
mpvue实现左侧导航与右侧内容的联动
Oct 21 Javascript
uni-app实现点赞评论功能
Nov 25 Javascript
javascript运行机制之执行顺序理解
Aug 03 Javascript
js实现简单的无缝轮播效果
Sep 05 Javascript
解析js如何获取css样式
Dec 11 #Javascript
BootStrap轮播HTML代码(推荐)
Dec 10 #Javascript
JQuery.validationEngine表单验证插件(推荐)
Dec 10 #Javascript
JS产生随机数的用法小结
Dec 10 #Javascript
基于JavaScript实现随机颜色输入框
Dec 10 #Javascript
BootStrap中
Dec 10 #Javascript
jQuery Ajax请求后台数据并在前台接收
Dec 10 #Javascript
You might like
解析php中的fopen()函数用打开文件模式说明
2013/06/20 PHP
PHP设计模式之简单投诉页面实例
2016/02/24 PHP
PHP 中常量的知识整理
2017/04/14 PHP
使用jquery实现图文切换效果另加特效
2013/01/20 Javascript
JavaScript中for..in循环陷阱介绍
2013/11/12 Javascript
Jquery 改变radio/checkbox选中状态,获取选中的值(示例代码)
2013/12/12 Javascript
jQuery取id有.的值的方法
2014/05/21 Javascript
js打开windows上的可执行文件示例
2014/05/27 Javascript
修复bash漏洞的shell脚本分享
2014/12/31 Javascript
jquery利用命名空间移除绑定事件的方法
2015/03/11 Javascript
JS实现仿雅虎首页快捷登录入口及导航模块效果
2015/09/19 Javascript
基于JavaScript实现瀑布流布局(二)
2016/01/26 Javascript
前端页面文件拖拽上传模块js代码示例
2017/05/19 Javascript
vue在手机中通过本机IP地址访问webApp的方法
2018/08/15 Javascript
微信小程序用户位置权限的获取方法(拒绝后提醒)
2018/11/15 Javascript
vue图片上传组件使用详解
2019/12/23 Javascript
element-ui树形控件后台返回的数据+生成组织树的工具类
2020/03/05 Javascript
微信小程序自定义弹出层效果
2020/05/26 Javascript
Vue使用自定义指令实现拖拽行为实例分析
2020/06/06 Javascript
用map函数来完成Python并行任务的简单示例
2015/04/02 Python
再谈Python中的字符串与字符编码(推荐)
2016/12/14 Python
Python编程二分法实现冒泡算法+快速排序代码示例
2018/01/15 Python
Python之读取TXT文件的方法小结
2018/04/27 Python
Python3转换html到pdf的不同解决方案
2019/03/11 Python
django多种支付、并发订单处理实例代码
2019/12/13 Python
pandas将list数据拆分成行或列的实现
2020/12/13 Python
使用css如何制作时间ICON方法实践
2012/11/12 HTML / CSS
女性时尚在线:IVRose
2019/02/23 全球购物
请说出你所知道的线程同步的方法
2013/04/19 面试题
商务考察邀请函范文
2014/01/21 职场文书
2014三八妇女节活动总结范文四篇
2014/03/09 职场文书
授权委托书样本
2014/09/25 职场文书
2014房屋登记授权委托书
2014/10/13 职场文书
关于战胜挫折的名言警句大全!
2019/07/05 职场文书
python中对列表的删除和添加方法详解
2022/02/24 Python
MySql重置root密码 --skip-grant-tables
2022/04/11 MySQL