this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定,this最终指向调用它的对象。

1.函数调用模式

当一个函数并非一个对象的属性时,那么它就是被当做函数来调用的。在此种模式下,this被绑定为全局对象,在浏览器环境下就是window对象;

function fn(){
var a = "hello";
console.log(this.a); //undefined
console.log(this); //window }
fn();

2.方法调用模式

当函数被保存为一个对象的属性时,它就可称为这个对象的方法。当一个方法被调用时,this被绑定到这个对象上。如果调用表达式包含一个提取属性的动作(. 或 []),那么它被称为方法调用

var obj = {
name : "hello",
sayName : function(){
console.log(this.name); //hello
}
}
obj.sayName();

这里的this指向的对象是obj,因为调用这个sayName()函数是通过obj.sayName()执行的。

var obj = {
name : "hello",
obj2 : {
name : "world",
sayName : function(){
console.log(this.name); //world
console.log(this); //obj2
}
}
}
obj.obj2.sayName();

因为是obj.obj2调用的这个函数,所以指向obj2这个对象。

var obj = {
name : "hello",
obj2 : {
//name : "world",
sayName : function(){
console.log(this.name); //undefined
console.log(this); //obj2
}
}
}
obj.obj2.sayName();

同理,因为是obj.obj2调用的这个函数,所以指向obj2这个对象。

var name = "我是最外面的name";
var obj = {
name : "hello",
obj2 : {
name : "world",
sayName : function(){
console.log(this.name); //"我是最外面的name"
console.log(this); //window
}
}
}
var q = obj.obj2.sayName;
q();

q是全局变量,在全局环境下执行,this指向window;

3.构造函数调用模式

如果在一个函数前面加上new关键字来调用,那么就会创建一个连接到该函数的prototype成员的新对象,同时,this会被绑定到这个新对象上。这种情况下,这个函数就可以成为此对象的构造函数。

function fn(){
console.log(this);//fn
}
var a = new fn();

在构造函数,new出一个对象时,this指向这个构造函数,new关键字会改变this的指向;

function fn(){
this.name = "hello";
}
var a = new fn();
console.log(a.name); //hello

当用new关键字,返回的是一个对象,this指向的就是那个返回的对象;

如果返回的不是对象,this还是指向函数的实例,虽然null属于对象,但是返回null依然指向函数实例;

function fn(){
this.name = "hello";
return {};
}
var a = new fn();
console.log(a.name); //undefined
function fn(){
this.name = "hello";
return function(){ };
}
var a = new fn;
console.log(a.name); //undefined
function fn(){
this.name = "hello";
return function(){ };
}
var a = new fn;
console.log(a.name); //undefined
function fn(){
this.name = "hello";
return [];
}
var a = new fn;
console.log(a.name); //undefined
function fn(){
this.name = "hello";
return 1;
}
var a = new fn;
console.log(a.name); //hello
function fn(){
this.name = "hello";
return 1;
}
var a = new fn;
console.log(a.name); //hello
function fn(){
this.name = "hello";
return null;
}
var a = new fn;
console.log(a.name); //hello
function fn(){
this.name = "hello";
return undefined;
}
var a = new fn;
console.log(a.name); //hello

4.apply和call调用模式

JS中,函数也是对象,所有函数对象都有两个方法:apply和call,这两个方法可以让我们构建一个参数数组传递给调用函数,也允许我们改变this的值

var name = "window";
var obj = {
name : 'obj'
}
function sayName(){
console.log(this.name);
}
sayName();//window
sayName.apply(obj);//obj
sayName.call(obj);//obj
sayName.apply();//window
sayName.call(); //window

在全局范围内,this指向全局对象(浏览器下指window对象)

对象函数调用时,this指向当前对象

全局函数调用时,应该是指向调用全局函数的对象。

使用new关键字实例化对象时,this指向新创建的对象

当用apply和call上下文调用的时候指向传入的第一个参数;

js中的this指向问题(小计)的更多相关文章

  1. 理解js中this的指向

         学习自原文  http://www.cnblogs.com/pssp/p/5216085.html后的一点小结(原文作者总结的很棒^_^)! 关于js中this的指向,在函数定义的时候还无法 ...

  2. js中改变this指向的call、apply、bind 方法使用

    前言: 由于js 中this的指向受函数运行环境的影响,指向经常改变,使得开发变得困难和模糊,所以在封装sdk,写一些复杂函数的时候经常会用到this 指向绑定,以避免出现不必要的问题,call.ap ...

  3. js中this的指向

    在js中this的指向对于新手来说一定是个难题,但是如果你真正理解了的话,也就没什么问题啦,下面就来讲讲this吧. JS中,this的值取决于调用的模式(调用对象),而JS中共有4种调用模式: 1. ...

  4. JS中的this 指向问题

    我发现在对JS的学习中有很多朋友对this的指向问题还是有很大的误区或者说只是大致了解,但是一旦遇到复杂的情况就会因为this指向问题而引发各种bug. 对于之前学习过c或者是Java的朋友来说可能这 ...

  5. 轻松了解JS中this的指向

    JS中的this指向一直是个让人头疼的问题,想当初我学的是天昏地暗,查了好多资料,看的头都大了,跟他大战了那么多回合,终于把它搞定个七八分,其实往往都是我们复杂化了,现在就让大家轻松看懂this的指向 ...

  6. js中 this 的指向

    js中 this的指向一共存在3种地方: 1.全局的this; 2.构造函数的this; 3.call/apply; 一.全局的this: function test(){ this.d = 3;// ...

  7. 彻底理解js中this的指向,不必硬背。

    首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然 ...

  8. 了解学习JS中this的指向

    [转] 首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问 ...

  9. 彻底理解js中this的指向

    首先必须要说的是,this的指向在函数定义的时候是确定不了的,只有函数执行的时候才能确定this到底指向谁,实际上this的最终指向的是那个调用它的对象(这句话有些问题,后面会解释为什么会有问题,虽然 ...

随机推荐

  1. eclipse向tomcat部署站点发现没有class文件。

    其实大部分解决办法在网上都有的,例如这里: https://blog.csdn.net/shiyuehit/article/details/53262807 eclipse下无法自动编译或编译失败等问 ...

  2. Servlet(三):生命周期、常用方法、常见错误

    Servlet的生命周期:从第一次调用,到服务器关闭.如果在web.xml 中配置了load-on-startup则是从服务器开启到服务器关闭. 注意: * init方法是对Servlet进行初始化的 ...

  3. 初始Mkaefile

    初识MakefIle 在学习Linux过程中,我越发的觉得Linux系统给了使用者更大的自由,同时也就增加了学习的成本.在gcc下去调试代码,没有了熟悉的VS,没有的人性话的错误提示(当然Makefi ...

  4. ulimit -c unlimited的使用(转载)

    ulimit -c unlimited ulimint -a 用来显示当前的各种用户进程限制Linux对于每个用户,系统限制其最大进程数,为提高性能,可以根据设备资源情况,设置个Linux用户的最大进 ...

  5. 基于for循环的呼吸灯

    #include "stm32f10x.h" #include "stm32f10x_gpio.h" //#include "led.h" ...

  6. Mysql SQL执行错误:#1136

    情况:在插入数据时可能会遇到这种情况: 原因: 插入时的数据个数与表中的字段个数不一致 解决方法: 检查表中的字段数与代码中所插入的数据字段数是否一致 例如:以下为Salary表中结构  虽然ActI ...

  7. [TopCoder]棍子

    题目描述 你有一堆棍子.每个木棒的长度是一个正整数. 你想要一组棍子所有的棍子都有相同的长度.您可以通过执行零个或多个步骤来更改当前集合.每个步骤必须如下所示: 你选择一根棍子.所选棒的长度必须至少为 ...

  8. Java HotSpot(TM) 64-Bit Server VM warning

    Java HotSpot(TM) 64-Bit Server VM warning: INFO: os::commit_memory(0x00000007e4200000, 467140608, 0) ...

  9. Module(CP343-1)Advanced system error SDB generation Error in rule file or rule file not found

    报这个故障的原因是因为安装目录下缺少三个 err文件.只要从好的目录下拷贝过来即可. C:\Program Files (x86)\SIEMENS\Step7\s7wbx\rul

  10. 什么是Hash?Hash有哪些特性?

    Hash 把任意长度的输入通过散列算法变换成固定长度的输出 Hash的特性: 输入域无穷,输出域有限.例如:有无穷多个(在工程中可以具体到多少个,例如1000)输入参数经过hash函数映射后得到有限的 ...