JavaScript中的this其实没传说中的那么难,也没那么乱。

我们来分析下,this主要是跟它的执行环境有关。

而通常情况下,this都是放在函数体中或可执行的JS代码中(函数体除外)。

至于JS可执行代码中的this,用的不多,所以本文举例较少。

至于函数体中的this,我们只要弄清楚this所处的函数体是谁在调用,不就知道this是谁了吗?

注意:此文中的函数调用,是指该函数作为某对象的一个属性方法被执行,而不是单纯的在某个对象的作用域中执行就是调用

-------------------------------------------------------------------------------------------------------------

NO.1可执行代码中的this(包含在函数体中的this除外)

1. 全局代码中的this

alert(this)//window

2. HTML事件处理程序中的this

<input type="button" name="click" id="click" value="clicked" onclick="console.log(this)" />
<!--
输出结果:<input type="button" name="click" id="click" value="clicked" onclick="console.log(this)">
-->

NO.2  若this所在的函数体没有被对象调用,则this指向window(默认调用对象是window)。无论这个函数在哪,也无论这个函数体嵌套了多少层。

示例:

//第一层
function test1(){
console.log(this); //window
//第二层
function test2(){
console.log(this); //window
//第三层
function test3(){
console.log(this); //window
//第四层
function test4(){
console.log(this); //window
}
test4();
}
test3();
}
test2();
}
test1();

 分类举例:

1. 作为单纯的函数调用

function test(){
console.log(this); //window
}
test();

2. 作为构造函数

function person(name){
this.name = name;
this.type = "person";
this.eat = function(){
alert("eat");
}; console.log(this);
}
person(); // window
var person1 = new person("wlh"); //person1

函数内部的this指向新构建的对象,若没有,指向 window。

其实跟单纯的函数调用是一样的,只是有个一个高逼格的名称(构造函数)。(理解构造函数和普通函数的区别!)

3、对象函数

var name = "clever coder";
var person = {
name : "foocoder",
hello : function(sth){
console.log(this.name + " says " + sth);
}
}
person.hello("hello world"); // foocoder says hello world

this指向person对象,即当前对象。

此处的hello作为person的属性方法被执行,所以它的this指向了person

4、内部函数

var name = "clever coder";
var person = {
name : "foocoder",
hello : function(sth){
function sayhello(sth) {
console.log(this.name + " says " + sth);
};
sayhello(sth);
}
}
person.hello("hello world");//clever coder says hello world

在这个内部函数中,sayhello函数只是在person.hello的函数体内被执行。

但它并没有作为当前对象的属性方法被执行。所以这个内部函数仍然是属于没有对象调用,只是执行了。所以它内部的this指向 window

等弄清楚了this的指向问题,再来看call()、apply()、bind()改变后的this指向,不也是很明朗吗?

这三个函数只是单一的改变当前函数的this指向,不影响其他地方

-------------------------------------------------------------------------------------------------------------

测试看是否完全理解了

练习一,

var age = 19;
function person(){
var age = 20;
this.age = 21;
} console.log(age);
person();
console.log(age);

结果:

var age = 19;
function person(){
var age = 20;
// 若没有明确的调用对象(默认window调用),则此处的this相当于window,执行person()后,覆盖了全局变量age
this.age = 21;
} console.log(age); //
person();
console.log(age); //

练习二:

var person = {
age:19
} function person1(){
var age = 20;
this.age = 21; function person2(){
var age = 22;
this.age = 23;
}
person2(); }
console.log(person.age);
person1.call(person);
console.log(person.age); console.log(age);

结果:

var person = {
age:19
} function person1(){
var age = 20;
this.age = 21; function person2(){
var age = 22;
this.age = 23;
}
person2(); } //调用的是person对象的age属性的值
console.log(person.age); //
//执行person1,并利用call将person1中的this指向person对象。所以 this.age = person.age = 21
person1.call(person);
console.log(person.age); //
//这个跟'练习一'一样,若没有明确指出调用对象,则this指向window
console.log(age); //

本文算是从另一个角度去重新理解了JavaScript中的this

这是之前转载博客:详解JavaScript中的this ,

对JavaScript中this的理解的更多相关文章

  1. JavaScript中的闭包理解

    原创文章,转载请注明:JavaScript中的闭包理解  By Lucio.Yang 1.JavaScript闭包 在小学期开发项目的时候,用node.js开发了服务器,过程中遇到了node.js的第 ...

  2. javascript中 (function(){})();如何理解?

    javascript中 (function(){})();如何理解? javascript中: (function(){})()是匿名函数,主要利用函数内的变量作用域,避免产生全局变量,影响整体页面环 ...

  3. 关于javascript中闭包的理解

    闭包就是能够读取其他函数内部变量的函数. 在javascript中,只有函数内部的子函数可以读取局部变量,因此,我理解闭包就是定义在一个函数内部的函数. 例子: var f1 = function() ...

  4. 对JavaScript中闭包的理解

    在前端开发中闭包是一个很重要的知识点,是面试中一定会被问到的内容.之前我对闭包的理解主要是"通过闭包可以在函数外部能访问到函数内部的变量",对闭包运用的也很少,甚至自己写过闭包自己 ...

  5. 转:对JavaScript中闭包的理解

    关于 const     let      var  总结: 建议使用 let  ,而不使用var,如果要声明常量,则用const. ES6(ES2015)出现之前,JavaScript中声明变量只有 ...

  6. JavaScript 中this 初步理解笔记

    Javascript中函数中的this通常指向的是函数的拥有者,这个拥有者就是上下文执行对象:另外一点需要注意,this只能在javascript函数内部使用.

  7. javascript中的原型理解总结

    经过几天研究查找资料,对原型终于有点理解了,今天就做下总结,不对之处,希望各位能够提出. 1.每一个Javascript对象(null除外)都和另一个对象相关联,“另一个”对象就是我们今天所要总结的原 ...

  8. javascript 中{}和[] 的理解

    下面的一段解释是摘抄的,基本理解正确,做个记录.其实js中数组其实就是对象,typeof(['a', 'b', 'c'])//测试之后结果为 :  "object" 一.{ } 大 ...

  9. 第二话:javascript中闭包的理解

    闭包是什么? 通过闭包,子函数得以访问父函数的上下文环境,即使父函数已经结束执行. OK,我来简单叙述下,先上图. 都知道函数是javascript整个世界,对象是函数,方法是函数,并且js中实质性的 ...

随机推荐

  1. android log写入机制

    这几天和华为的leader面试了下.感觉不错.关键是小女.不容易.是技术面啊.我说的不容易不是面试不容易,是说在华为写代码的小女不容易.哥走南闯北这么多年,女人代码写的好真不多. 其实在任何时候,只要 ...

  2. FZU 2087 统计树边

    这题第一直觉就是和CF第三次教育场的E题是一样的, http://codeforces.com/contest/609/problem/E 然后直接拉过来代码改了改,提交返回MLE.FZU内存开的小, ...

  3. 源码解析-knockout源码准备

    准备包括心理和资源两方面. 心理 我看过一句话说,当你用一个框架时,不要忙着看一遍使用教程就开始写项目,先去看看框架原理. 这句话我深以为然.现今前端快速发展,很多前端攻城狮都很茫然:框架更新太快了, ...

  4. iOS开发——Localizable.strings

    这篇写的不多,但是绝对诚意满满.不会像别人一样,要不不详细,要不罗里吧嗦一堆. 1.创建Localizable.strings文件 Command+N—>iOS—>Resource—> ...

  5. iOS开发 missing iOS distribution signing identity for 。。。

    苹果真是不让人省心,新年一来上传APP,就出现Missing iOS Distribution signing indetity for xxx 于是就把证书删了做,做了删了再重做,还是不行 百度了一 ...

  6. 异常捕获拒绝闪退 让应用从容的崩溃UncaughtExceptionHandler

    虽然大家都不愿意看到程序崩溃,但可能崩溃是每个应用必须面对的现实,既然崩溃已经发生,无法阻挡了,那我们就让它崩也崩得淡定点吧. IOS SDK中提供了一个现成的函数 NSSetUncaughtExce ...

  7. Warning: Attempt to present on whose view is not in模态跳转问题

    错误分析:            controller A present controller B ,前提是A的view要存在,如果不存在,就会报这个错.   解决方法:             将 ...

  8. Memcached源码分析之内存管理

    先再说明一下,我本次分析的memcached版本是1.4.20,有些旧的版本关于内存管理的机制和数据结构与1.4.20有一定的差异(本文中会提到). 一)模型分析在开始解剖memcached关于内存管 ...

  9. mongodbVUE基本操作(转)

    基本操作: http://my.oschina.net/u/1026531/blog/188336

  10. Jquey里的同步请求和异步请求

    1.同步请求 发送了同步请求后  会一直等待 先执行 alert("result:" + d); temp = d;   在执行alert("this is last:& ...