`
myali88
  • 浏览: 28650 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

理解JavaScript关键字this

    博客分类:
  • web
阅读更多

原文:Understanding JavaScript's this keyword

    几天前,我写了一篇关于面向方面的JavaScript的文章,说明了如何利用包装器来替换给定的函数或方法。为了全面地理解这一概念,正确理解JavaScript对其关键字“this”的处理是很有帮助的。如何在JavaScript各种各样的上下文中确定this指的是什么,本文将给出一个简单概要。

    让我们从下面 Bob 的例子开始:

var Bob = {
  name: "Bob",
  greet: function() {
    alert( "Hi, my name is " + this.name );
  }
};

    在这里,我们创建了一个拥有两个成员的Object实例,一个简单的字符name,和一个包含对name引用的方法greet,当执行 Bob.greet()方法时,greet()函数用Bob作为this的对象。现在,让我们来看看同样的Bob.greet()在新的对象上执行会如何:

var Alice = {
  name: "Alice",
  greet: Bob.greet
};

    考虑下面哪一个才是Alice.greet()的输出呢?

   1.  "Hi, my name is Bob", or
   2. "Hi, my name is Alice" 

    如果你选择的是“2”,对了!Bob的greet函数中“this.name”的直到函数真正执行时才会被解析,所以,当Alice.greet()被调用时,函数greet()的this被设置为了Alice。但是,如果调用函数本身,而不是作为某个对象的方法,会发生什么呢?看看下面这个:

var unboundGreet = Bob.greet;
unboundGreet();

    你预测函数unboundGreet()会输出什么呢?答案是“"Hi, my name is”。这是因为当一个未绑定的函数被调用时,“this”被设置为了全局对象window,而window.name并没有定义,所以就产生空字符。

    下面的例子你将会看到隐含的未绑定会令调试很头痛:

setTimeout( Bob.greet, 1000 ); // Call Bob.greet 1 second from now

    开发者可能希望Bob.greet()会在一秒后调用,它绑定到了Bob上就会输出“Hi, my name is Bob”,但是这种预期并没有出现,相反,这个greet()方法只能称为未绑定,其输出结果同unboundGreet()是一样的。下面这个等效的代码或许能更清楚地说明其中的原由:

var unboundGreet = Bob.greet;
setTimeout( unboundGreet, 1000 );

    在这里,很明显,在执行时间开始(一秒后)时,函数greet()是一个未绑定的。当你把一个对象的方法设为一个事件处理器时,相同情况也会发生。看看下面的HTML:

<a id="clickme" href="">Greetings!</a>

    添加如下的JavaScript:

document.getElementById("clickme").onclick = Bob.greet;

    可能我们预期这会触发链接输出“Hi, my name is Bob”,但当点击它时,结果又和调用unboundGreet()是一样的。
    解决隐含未绑定的问题方法就是创建一个函数,用它来包装无范围的方法(the bound method)。大多数JavaScript库都包含了这样的助手,多数时候是通过向Function.prototype添加一个bind方法来完成的。
    这里就不用这种方式,下面用一个简单的例子说明如何建仓这样的包装器(wrapper)。

var bobsGreet = function() {
  Bob.greet();
};

setTimeout( bobsGreet, 1000 );

    或者更简单一点,

setTimeout( function(){

  Bob.greet();

}, 1000 );

    这就是本文的全部内容了。

分享到:
评论
2 楼 chenxiang105 2011-08-24  
希望除了多答点问题之余 多抽点时间写点好文章共享下..
我喜欢javaeye简洁的风格但是善于总结的人 貌似已经大多不再更新iteye了.
1 楼 geniuswxk 2011-08-22  
在将Bob.greet定义到其他变量时,如后面加()效果会和直接调用Bob.greet()效果一样,如
var Alice = {
  name: "Alice",
  greet: Bob.greet[color=darkred]()[/color]
};

这里面有什么玄机没?方法的定义和执行可以看成不同类型的变量不?

相关推荐

    JavaScript关键字保留字属性及说明

    ### JavaScript关键字、保留字及其属性详解 #### 一、JavaScript 关键字与保留字 JavaScript是一种广泛使用的脚本语言,用于网页开发以及其他多种用途。它包含了一系列的关键字和保留字,这些词在语言中具有特殊的...

    深入理解JavaScript中的this关键字

    JavaScript中的`this`关键字是编程过程中经常会遇到的一个关键概念,尤其在面向对象编程中起着至关重要的作用。`this`的值取决于它被调用时的上下文,而不是定义时的位置,这使得它有时会显得有些复杂。在这个深入...

    JavaScript中this关键字使用方法详解

    在JavaScript编程语言中,`this`关键字是一个至关重要的概念,它常常引发初学者的困惑,因为它的值在不同的上下文中可能会有所不同。`this`关键字主要用来引用对象的上下文,或者说是当前执行环境中的对象。在本文中...

    跟我学习javascript的this关键字

    在JavaScript中,`this`关键字是一个经常被讨论的话题,因为它在不同的上下文中具有不同的含义。`this`关键字是动态绑定的,也称为运行期绑定,这意味着它会根据函数调用的方式和所在的上下文来改变其指向。这种动态...

    精通JavaScript的this关键字_.docx

    JavaScript中的`this`关键字是一个非常重要的概念,它在编程中起着至关重要的作用,尤其是在对象方法的上下文中。`this`关键字的用法类似于自然语言中的代词,它用来引用当前执行上下文的对象,帮助开发者避免命名...

    详解JavaScript中this关键字的用法_.docx

    总结起来,理解JavaScript中的`this`关键字至关重要,因为它在不同情境下有不同的行为。在编写代码时,正确地理解和使用`this`可以帮助我们更好地控制代码的执行环境,避免安全问题,比如避免意外修改全局变量,确保...

    如何使用Javascript中的this关键字

    在JavaScript中,`this`关键字是一个非常重要的概念,它用于引用函数执行时的上下文对象。`this`的值取决于函数被调用的方式,而不是函数定义的位置。在不同的场景下,`this`的指向会发生变化,这使得它成为...

    关于javascript中this关键字(翻译+自我理解)

    函数的copy(复制)和refer(引用)问题也是理解JavaScript中this的一个要点。在复制函数的场景下,实际上是在创建函数的一个副本,这个副本的this可能会与原始函数不同。而在引用函数的场景下,函数本身的this不变...

    JavaScript的this关键字的理解

    当一个函数创建后,一个关键字this就随之(在后台)创建,它链接到一个对象,而函数正是在这个对象中进行操作。换句话说,关键字this可在函数中使用,是对一个对象的引用,而函数正是该对象的属性或方法。 让我们来看...

    深入解析JavaScript编程中的this关键字使用

    JavaScript中的`this`关键字是一个非常核心的概念,它用于在函数执行时引用当前上下文的对象。在JavaScript中,`this`的值取决于函数被调用的方式,而不是函数定义的位置。理解`this`的工作原理对于深入掌握...

    深化理解Javascript中this的作用域_.docx

    在JavaScript中,`this`关键字的作用域是一个经常让人困惑的主题,尤其对于那些习惯于其他面向对象语言(如Java或C++)的开发者来说。在这些语言中,`this`通常固定地指向当前对象实例。然而,在JavaScript中,`this...

    深入理解Javascript中的this关键字

    总之,深入理解JavaScript中的this关键字是提高编程技能不可或缺的一部分。通过掌握this在不同上下文中的行为和如何正确地控制this的绑定,开发者可以更有效地使用JavaScript编写出更加结构化和可重用的代码。

    javaScript基础关键字介绍.docx

    这些关键字对于理解和编写JavaScript代码至关重要。随着JavaScript的发展,新的关键字和特性不断被引入到语言中,因此保持学习和更新知识是非常重要的。希望本篇文章能够帮助读者更好地掌握JavaScript的基础知识。

    深入理解JavaScript系列(13) This? Yes,this!

    总之,理解JavaScript中的this关键字需要对执行上下文、函数调用方式、以及函数如何被定义和使用有深入的认识。通过本文对this关键字的分析,我们可以得到一个更加清晰和全面的理解,并在实际开发中更加自如地运用。

    关于js里的this关键字的理解

    对于JavaScript中的`this`关键字,还有更多细节和特殊案例需要理解和注意。例如,`this`在`setTimeout`或者`setInterval`中的行为与普通函数调用类似。另外,严格模式(`'use strict'`)对`this`的指向有更严格的...

    javascript中onclick(this)用法介绍

    接下来,我们要讨论的是在onclick事件处理器中使用的关键字this。在JavaScript中,this关键字总是指向正在执行的函数的上下文对象,也就是调用该函数的对象。在事件处理函数中,this通常指向触发事件的元素。因此,...

    javascript中的关键字

    理解这些关键字对于编写高效、可靠的JavaScript代码至关重要。 #### 基本控制结构关键字 1. **break**:用于立即退出循环或`switch`语句。 2. **case**:与`switch`语句结合使用,指定可能匹配的值。 3. **catch**...

    javascript的this关键字详解

    总结来说,理解JavaScript中的`this`关键字及其在不同环境中的行为是编写高效、可维护的JavaScript代码的关键。通过深入学习`this`的原理和应用场景,开发者能够更好地掌握JavaScript的面向对象编程。

Global site tag (gtag.js) - Google Analytics