JS中的 this
JS中的 this 变化多端,似乎难以捉摸,但实际上对 this 的解读,还是有一定规律的。
分析this,该如何下手呢?下面有一个函数
function show(){
alert(this);
}
那 this 是什么呢?当然没有答案,因为要得到 this,首先要看调用处。调用决定this ,如下
oBtn.onclick = show; // 此时 this 就是 oBtn
show(); // this 是 window 或 undefined,具体要看方法的所有者和运行模式
new show() // this 是 new 出来的对象
下面分析几种单一情况下的 this:
1、事件中,this指向触发事件的对象
1.1、作为事件处理程序的值
oBtn.onclick = function(){
alert(this); // oBtn
}
1.2、行间事件
<input type="button" value="按钮" id="btn" onclick="show()" />
function show(){
alert(this); // this指该按钮
}
1.3、同样是行间事件
<input type="button" value="按钮" id="btn" onclick="alert(this)" />
<!-- this也是指该按钮 -->
2、this 指向其所属的对象。包括普通函数,可以看成是 window 的对象。
2.1
var arr=[1,2,3];
arr.show=function ()
{
alert(this); // this指向arr数组
};
arr.show();
2.2
function show(){
alert(this); // window
}
show();
等价于(此处只关心 this)
window.show=function ()
{
alert(this); //window
};
window.show();
3、函数嵌套
function show(){
function show1(){
alert(this);
}
show1();
}
show();
结果:
3.1、正常下 this 指向 window;
3.2、严格模式下,this 为 undefined (当然浏览器得支持严格模式);
可以这么理解:this指向其所属的对象,此时show1谁都不属于,所以是undefined
4、定时器中,this 指向 window,可以这么理解:隔一段时间后,由 window 执行一个函数,所以 this 指向 window;
setTimeout(function(){
alert(this); // window
}, 1000);
5、apply 和 call,正如我们知道的,call 和 apply 可以改变 this 的值
function show(){
alert(this); // this 指向数组
}
show.call([1,2,3]);
6、new 对象
*构造函数:构造函数式相对的, new Person()时,Person 就叫构造函数,直接调用"Person()"时,Person就是一个普通的函数;
function Person (){
alert(this); // new 出来的 Person 对象
}
var person = new Person();
new的作用:
1.将 this 指向一个新建的空对象
2.return this
所以上面的代码实际是这样的:
function Person (){
// var obj = new Object();
// this = obj;
alert(this); // new 出来的 Person 对象
// return this;
}
var person = new Person();
单种情况的处理基本就如上了,如果复合情况怎么办?如下:
function show(){
alert(this);
}
var arr1=[1,2,3];
arr1.show=show;
setTimeout(new arr1.show(), 1000);
此时就需要对上述几种情况按照优先级排一个顺序了
this 优先级从高到低为:
| 优先级 | 情景 | this 的值 | 备注 |
| 1 | new | new出来的空 object | |
| apply / call | 传入的参数 | 并列第一,apply / call不能和 new 同时出现 new arr1.show.apply(“1”); // 报错 |
|
| 2 | 定时器 | window | |
| 3 | 事件 | 发生事件的元素 | |
| 4 | 方法 | 所有者 | |
| 5 | 其他(嵌套等) | window || undefined | 看是否为严格模式 |
注:不管如何修改this,this只会影响一层,比如下面这个
function show(){
alert(this); // this 为数组 [1,2,3]
function show1(){
alert(this); // window || undefined
}
show1();
}
show.apply([1,2,3]);
下面的 this 就没什么疑问了吧(某些代码纯粹是为了判断 this 而写,实际中并不会遇到–面试除外)
function show()
{
alert(this);
}
var arr1 = [1,2,3];
arr1.show = show;
show(); //window
arr1.show(); //arr1
new show(); //object
new arr1.show(); //object
//document.onclick = show; //点击时 document
document.onclick = arr1.show; //点击时 document
new document.onclick(); //object
setTimeout(show, 100); //window
setTimeout(arr1.show, 200); //window
setTimeout(document.onclick, 100); //window
setTimeout(new document.onclick(), 200); //object
window.onload = function ()
{
arr1.show(); //arr1
};
new (function (){
alert(this); //object
arr1.show(); //arr1
})();
JS中的 this的更多相关文章
- 5.0 JS中引用类型介绍
其实,在前面的"js的六大数据类型"文章中稍微说了一下引用类型.前面我们说到js中有六大数据类型(五种基本数据类型 + 一种引用类型).下面的章节中,我们将详细讲解引用类型. 1. ...
- 【repost】JS中的异常处理方法分享
我们在编写js过程中,难免会遇到一些代码错误问题,需要找出来,有些时候怕因为js问题导致用户体验差,这里给出一些解决方法 js容错语句,就是js出错也不提示错误(防止浏览器右下角有个黄色的三角符号,要 ...
- JS中给正则表达式加变量
前不久同事询问我js里面怎么给正则中添加变量的问题,遂写篇博客记录下. 一.字面量 其实当我们定义一个字符串,一个数组,一个对象等等的时候,我们习惯用字面量来定义,例如: var s = &quo ...
- js中几种实用的跨域方法原理详解(转)
今天研究js跨域问题的时候发现一篇好博,非常详细地讲解了js几种跨域方法的原理,特分享一下. 原博地址:http://www.cnblogs.com/2050/p/3191744.html 下面正文开 ...
- 关于js中的this
关于js中的this this是javascript中一个很特别的关键字,也是一种很复杂的机制,学习this的第一步就是要明白this既不指向函数自身也不指向函数的词法作用域,this实际上是函数被调 ...
- 表值函数与JS中split()的联系
在公司用云平台做开发就是麻烦 ,做了很多功能或者有些收获,都没办法写博客,结果回家了自己要把大脑里面记住的写出来. split()这个函数我们并不陌生,但是当前台有许多字段然后随意勾选后的这些参数传递 ...
- JS中 call() 与apply 方法
1.方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 定义:调用一个对象的一个方法,以另一个对象替换当前对象. 说明: call ...
- 在node.js中,使用基于ORM架构的Sequelize,操作mysql数据库之增删改查
Sequelize是一个基于promise的关系型数据库ORM框架,这个库完全采用JavaScript开发并且能够用在Node.JS环境中,易于使用,支持多SQL方言(dialect),.它当前支持M ...
- 分析js中的constructor 和prototype
在javascript的使用过程中,constructor 和prototype这两个概念是相当重要的,深入的理解这两个概念对理解js的一些核心概念非常的重要. 我们在定义函数的时候,函数定义的时候函 ...
- 如何在Node.js中合并两个复杂对象
通常情况下,在Node.js中我们可以通过underscore的extend或者lodash的merge来合并两个对象,但是对于像下面这种复杂的对象,要如何来应对呢? 例如我有以下两个object: ...
随机推荐
- Yii rabc角色权限管理文章推荐
yii的这个rbac太通用,太灵活,有时候理解起来有困难.也是初学这个,推荐一个不错的文章:http://www.yiiframework.com/wiki/136/getting-to-unders ...
- redis 手册
一.概述: 在该系列的前几篇博客中,主要讲述的是与Redis数据类型相关的命令,如String.List.Set.Hashes和Sorted-Set.这些命 令都具有一个共同点,即所有的操作都是针对与 ...
- [学习笔记]设计模式之Singleton
写在前面 为方便读者,本文已添加至索引: 设计模式 魔法手札索引 在前几篇笔记中,我们有了解了部分对象创建型模式,包括Builder(建造者).Abstract Factory(抽象工厂)和Facto ...
- Java分布式优秀资源集合
这里充分尊重原作者的版本,学习了知识要感激原博主 Runnable.Callable.Executor.Future.FutureTask关系解读 http://blog.csdn.net/zhang ...
- android关机充电
1.关机充电其实是进入adb shell很快的方式! 2.手机关机时候插入USB,手机将进入关机充电模式,那么这个模式究竟是怎么进行的,这里分析如下! (1)uboot:这里代码大概浏览了一下:u-b ...
- Test Bench基础知识笔记
学的内容多了,好多指令和用法都容易遗忘和混淆,出现这种情况就需要勤记笔记,忘记了多翻阅几次,基本上就能完全记住了. [`timescale 1ns/1ps]前一个1ns表示时延时间,后一个1ps表示时 ...
- 最简单的基于FFMPEG的视频编码器(YUV编码为H.264)
本文介绍一个最简单的基于FFMPEG的视频编码器.该编码器实现了YUV420P的像素数据编码为H.264的压缩编码数据.编码器代码十分简单,可是每一行代码都非常重要,适合好好研究一下.弄清楚了本代码也 ...
- RFC 文档(中文与英文)
http://man.chinaunix.net/develop/rfc/default.htm https://www.rfc-editor.org/retrieve/ http://www.iet ...
- hdu2041java
超级楼梯 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- JS如何封装一些列方法为一个对象的操作,然后集中管理这些操作,方便修改和调用
var Api = { ajax:{ // 添加项目 旧! add_project : function(pro_name, html, css, js,callback) { $.post(&quo ...