Javascript中的this指向。

一、JavaScript中的函数

  在了解this指向之前,要先弄明白函数执行时它的执行环境是如何创建的,这样可以更清楚的去理解JavaScript中的this指向。

function fn(x,y,name){
    var str1=x;
    var str2=y;   this.name=name;
    function(){
        alert(str1,str2);
    }
}fn(1,1,Admin);

  当调用fn(1,1,Admin)时,首先函数会创建一个活动对象,也叫做变量对象,接着为函数调用创建一个类似数组的arguments对象用于保存传入的参数,再为执行环境分配作用域链,初始化变量,将函数内部除了实参和函数声明有值外,都被初始化为undefined,最后为this关键字赋值,至此函数环境创建成功,成功后开始将形参逐个进行赋值,最后执行alert语句。

二、JavaScript中的this

  JavaScript中的this到底指向谁?!在不同的环境下this可以随时变换指向,是容易让人头晕的的概念。

  了解完函数执行环境的创建,再来看看函数中的this指向问题,在JavaScript中的函数既可以被当做普通函数执行,也可以被当做对象的方式执行,这是导致this指向丰富的原因之一。在主流的面向对象的语言中(例如Java,C#等),this含义是很明确的,就是指向当前对象。一般在编译期就已经绑定。而JavaScript中this是在运行期进行绑定的,这也会导致JavaScript中this具有多重含义。JavaScript中的this由于是在运行期进行绑定的,所以JavaScript中的this可以是全局对象、当前对象或者任意对象,这取决于函数的调用方式

  JavaScript中函数的调用有以下几种方式:作为构造函数调用,作为对象方法调用,作为函数调用,和使用apply()或call()调用。下面就要通过举例子来慢慢理解。

  1.作为构造函数调用

function Fn(a){
    this.a=a; // this ?
}
var obj1=new Fn(1);
obj1.a; //1
var obj2=Point(2);
obj2.a; //报错 obj2是一个空对象undefined
window.a; //2

  当作为对象方法调用时,job1是根据构造函数创建的实例化对象,那么在构造函数中的this.a=1就指向了obj1,构造函数中的this都指向实例化对象。

  而obj2没有通过new的方式创建对象,所以obj2是一个空对象,obj2.a找不到,所以是undefined,即this.a相当于window.a。

  2.对象方法调用

var obj={
    x:1,
    fn:{
        fn1:function (){
            console.log(this.x);
    }
    }
}
obj.fn.fn1(); //undefined

  对象方法调用中的this指向包含它的对象,这里只需要注意一点,不用new方法创建的对象,其中的this只指向包含它的对象fn,并不会指向fn的父级obj。

  3.作为函数直接的调用

function fn() {
    alert(this.a);
};
var a="1";fn();div.onclick=function(){  alert(this);}

  函数fn()被调用时,开始给this赋值,首先判断this不是new出来的对象中的,所以不会指向实例化对象,然后也不是被某个元素调用的,所以最后将window赋值给它。

  在平时最常用的点击事件中,onclick事件是由div绑定的,所以在事件中,this就指向调用的元素,即指向div。

  4.使用call()和apply()进行调用

  call()和apply()的作用就是用来改变this指向,它们的第一个参数都是this要指向的对象。

function Fn(x){
     this.x = x;
     this.fn1= function(x){
         this.x = x;
     }
}
var obj1=new Fn(0);
var obj2={x: 0};
obj1.fn1.apply(obj2, [1]);
obj1.x; //0obj2.x; //1

  上面这段代码中,obj1是new出来的实例化对象,所以this指向实例化对象,即obj1,所以obj1.x的结果为0,而apply在执行函数fn1时改变了this指向,使它指向了obj2,所以obj1.fn1.apply(obj2,[1])实际上是相当于obj2.fn1(1),apply让obj1中的fn1方法赋值给了obj2,所以结果为1。

  三、总结

  通过这些例子的总结,大体可以总结出判断this的方法,如果使用new实例化的对象,那么函数中的this就指向实例化对象,如果不是new出来的对象,那就找是否是某个元素调用了这个函数,那么this就指向调用它的元素,如果不是以上两种情况,那么this就指向全局变量window,当然this指向都可以使用call()和apply()来进行改变。

  关于JavaScript中this的指向还有许多问题要慢慢理解,在不同的“场景”中有不同的变化,需要在平时多用多体会。以上就是我对JavaScript中this指向的理解,如有纰漏,还望指正。

  另外附上一篇大神翻译的文章作为结尾,关于this在具体使用时遇到的问题:http://www.cnblogs.com/yuanzm/p/4150558.html

  

  

时间: 2024-08-10 21:28:14

Javascript中的this指向。的相关文章

javascript中this的指向

作为一个前端小白在开发中对于this的指向问题有时候总是会模糊,于是花时间研究了一番. 首先this是JS的关键字,this是js函数在运行是生成的一个内部对象,生成的这个this只能在函数内部使用. 但是随着函数使用场合的不同,this的值会发生变化.有一个原则不会变,那就是this指的是,调用函数的那个对象. demo1: 此时函数运行的结果是 1 ,x是全局变量,因为匿名函数demo()是被window调用的,原始写法是window.demo(),因为demo()是被window调用的,所

javascript中this的指向问题

想学好javascript不是一件容易的事,而this就是其中一道坎,尤其是在用js进行面向对象开发的时候. 实际上,想要彻底搞懂this的指向确实不是一件容易的事,在<你不知道的javascript 上卷>一书中更是花了很大篇幅详细总结了this的四种指向情景.我在艰难的啃完这本书和大量阅读<javascript高级程序设计>.博文.以及大量实践中终于是弄懂了this.确实是,有些知识是需要反复验证.理解.总结,直至豁然开朗,构建成属于自己的理论体系. 那么进入正文: javas

JavaScript中的this指向

this是谁 技术一般水平有限,有什么错的地方,望大家指正. this代指当前对象super调用父类的构造函数,应表会运网数物,加载驱动建立链接执行SQL处理结果,直到现在每想起这三点就能想起我上大学的时候,故事背景都是不同的有时候是我玩的正high的时候有时候是我快要睡觉,但是结果都是一致的就是让老师教育几句.现在就介绍一下Javascript中的this. 说this的我们一般都说指向,代表,因为它不是固定的,今天是王麻子明天可能就是二狗子,它是谁不能确定,但是有一点是肯定的它永远指向让它起

JAVASCRIPT中的THIS指向问题

在深入学习JavaScript之后,我们越来越多的会遇到函数或者在对象内部中,对于this的指向问题的疑惑,其实基本上每一个编程语言中都有一个this,这个this的指向都是大同小异,你也可以汉化它的意思,this的意思是这个,就是本身的意思,那么在JavaScript中,我们的this代替的那个本身到底会随着代码情况的不同而有什么变化呢?今天,我们就来一体探讨一下JavaScript中关于this的指向问题: 首先呢,this可以指向window对象,和其他调用它的对象,当然,在严格模式下,它

关于JavaScript中this的指向问题

JavaScript中设计最出色的就是它的函数实现,函数是JS的基本单元,而this又是函数里面特别重要的一个属性. this和其他的语言指向不太一样,在JavaScript中this的值取决于调用的模式. 在JavaScript中一共有4种调用模式:方法调用模式.函数调用模式.构造器调用模式和apply调用模式.不同的模式在如何初始化this上存在差异. 先说下方法调用模式和函数调用模式的区别:当一个函数被保存为对象的一个属性时,我们称他为一个方法.当一个函数并非一个对象的属性时,那么它就是被

Javascript 中的this 指向的对象,你搞清楚了吗?

Javascript 中的this 总让人感到困惑,你能分清以下三种test1(),test2(),test3() 情况下的输出吗? 注:以下Javascript运行环境中为浏览器 //1 this在全局函数中使用 var x = 1; function test1() { var  x = 5; alert(this.x); } function _test2() { this.x = 5; alert(this.x); } //2 this 在构造函数中 new 中使用 function t

javascript中this的指向(着重分析匿名函数的this指向)

1.this的意义(this是什么?): http://www.ruanyifeng.com/blog/2010/04/using_this_keyword_in_javascript.html this是Javascript语言的一个关键字. 它代表函数运行时,自动生成的一个内部对象,只能在函数内部使用. https://zhuanlan.zhihu.com/p/23804247 this 是你 call 一个函数时传的 context https://dmitripavlutin.com/g

JavaScript 中的this指向问题

全局执行     首先,我们在全局环境中看看它的 this 是什么:     浏览器:     console.log(this);     // Window {speechSynthesis: SpeechSynthesis, caches: CacheStorage, localStorage: Storage, sessionStorage: Storage, webkitStorageInfo: DeprecatedStorageInfo…}     可以看到打印出了 window 对

第149天:javascript中this的指向详解

js中的this指向十分重要,了解js中this指向是每一个学习js的人必学的知识点,今天没事,正好总结了js中this的常见用法,喜欢的可以看看: 1.全局作用域或者普通函数中this指向全局对象window. 1 //直接打印 2 console.log(this) //window 3 4 //function声明函数 5 function bar () {console.log(this)} 6 bar() //window 7 8 //function声明函数赋给变量 9 var ba