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

转载 2007年09月11日 17:52:00
­
在面向对象编程语言中,对于this关键字我们是非常熟悉的。比如C++、C#和Java等都提供了这个关键字,虽然在开始学习的时候觉得比较难,但只要理解了,用起来是非常方便和意义确定的。JavaScript也提供了这个this关键字,不过用起来就比经典OO语言中要"混乱"的多了。
­
    下面就来看看,在JavaScript中各种this的使用方法有什么混乱之处?
­
    1、在HTML元素事件属性中inline方式使用this关键字: <div onclick="
// 可以在里面使用this
">division element</div>
­
    我们一般比较常用的方法是在此使用:javascirpt: EventHandler(this),这样的形式。不过这里其实可以写任何合法的JavaScript语句,要是高兴在此定义个类也可以(不过将会是个内部类)。这里的原理是脚本引擎生成了一个div实例对象的匿名成员方法,而onclick指向这个方法。
­
    2、用DOM方式在事件处理函数中使用this关键字:
<div id="elmtDiv">division element</div>
<script language="javascript">
var div = document.getElementById('elmtDiv');
div.attachEvent('onclick', EventHandler);
function EventHandler()
{
    // 在此使用this
}
</script>
­
     这时的EventHandler()方法中的this关键字,指示的对象是IE的window对象。这是因为EventHandler只是一个普通的函数,对于attachEvent后,脚本引擎对它的调用和div对象本身没有任何的关系。同时你可以再看看EventHandler的caller属性,它是等于null的。如果我们要在这个方法中获得div对象引用,应该使用:this.event.srcElement。
­
    3、用DHTML方式在事件处理函数中使用this关键字:
<div id="elmtDiv">division element</div>
<script language="javascript">
var div = document.getElementById('elmtDiv');
div.onclick = function()
{
    // 在此使用this
};
</script>
­
     这里的this关键字指示的内容是div元素对象实例,在脚本中使用DHTML方式直接为div.onclick赋值一个EventHandler的方法,等于为div对象实例添加一个成员方法。这种方式和第一种方法的区别是,第一种方法是使用HTML方式,而这里是DHTML方式,后者脚本解析引擎不会再生成匿名方法。
­
    4、类定义中使用this关键字:
  function JSClass()
  {
      var myName = 'jsclass';
      this.m_Name = 'JSClass';
  }
  JSClass.prototype.ToString = function()
  {
      alert(myName + ', ' + this.m_Name);
  };
  var jc = new JSClass();
  jc.ToString();
­
    这是JavaScript模拟类定义中对this的使用,这个和其它的OO语言中的情况非常的相识。但是这里要求成员属性和方法必须使用this关键字来引用,运行上面的程序会被告知myName未定义。
­
­
­
 

JavaScript中this关键字含义及其最佳实践(一)

在JavaScript中this关键字非常灵活, 在不同的情况下有不同的含义. 对于初学者来说 比较难以掌握, 即使是有经验的开发人员, 亦容易犯错. Google 一下 understanding ...
  • FuDesign2008
  • FuDesign2008
  • 2014年01月18日 21:21
  • 2103

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

在 面向对象编程语言中,对于this关键字我们是非常熟悉的。比如C++、C#和Java等都提供了这个关键字,虽然在开始学习的时候觉得比较难,但只要理 解了,用起来是非常方便和意义确定的。JavaScr...
  • dreamwdt
  • dreamwdt
  • 2006年09月05日 17:15
  • 503

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

在面向对象编程语言中,对于this关键字我们是非常熟悉的。比如C++、C#和Java等都提供了这个关键字,虽然在开始学习的时候觉得比较难,但只要 理解了,用起来是非常方便和意义确定的。JavaScr...
  • xiaobai251206725
  • xiaobai251206725
  • 2010年10月14日 22:06
  • 232

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

 在面向对象编程语言中,对于this关键字我们是非常熟悉的。比如C++、C#和Java等都提供了这个关键字,虽然在开始学习的时候觉得比较难,但只要理解了,用起来是非常方便和意义确定的。JavaScri...
  • Peak915
  • Peak915
  • 2005年09月13日 14:07
  • 757

Java学习笔记:详解this关键字

this关键字在Java中表示以下概念: |·调用类中的属性:this.属性; |·调用类中的方法:this.方法(); |·调用类中的构造:this(); |·表示当前对象 ...
  • java1992
  • java1992
  • 2010年08月23日 11:09
  • 3790

javascript中this关键字的详细解析

Javascript是一门基于对象的动态语言,也就是说,所有东西都是对象,一个很典型的例子就是函数也被视为普通的对象。Javascript可以通过一定的设计模式来实现面向对象的编程,其中this “指...
  • wyj880220
  • wyj880220
  • 2012年02月29日 15:00
  • 1709

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

    5、为脚本引擎内部对象添加原形方法中的this关键字:   Function.prototype.GetName = function()   {       var fnName = thi...
  • zhaoqiang_jia
  • zhaoqiang_jia
  • 2007年09月11日 17:53
  • 311

java关键字this的用法

public void print(String name) { System.out.println("类中的属性 name=" + this.name); //成员变量 ...
  • github_37588138
  • github_37588138
  • 2017年02月27日 00:27
  • 98

JavaScript中this关键字详解

众所周知,JavaScript中this关键字在不同的场合,有不同的含义,本文主要介绍一下,各自场合,this的作用。...
  • psp0001060
  • psp0001060
  • 2016年08月28日 10:39
  • 309

Javascript中this关键字详解

Quiz 请看下面的代码,最后alert出来的是什么呢? 1 var name = "Bob"; 2 var nameObj ={ 3 name : "Tom",...
  • ypq5566
  • ypq5566
  • 2014年05月16日 09:05
  • 274
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JavaScript中this关键字使用方法详解 1
举报原因:
原因补充:

(最多只允许输入30个字)