`

[翻译]PPK 谈 JavaScript 的 this 关键字

 
阅读更多

原文:JavaScript - The this keyword

在 JavaScript 中 this 是最强的关键字之一。这篇贴文就是要告诉你如何用好 this。

下面先讲如何在event handling (事件处理)中用它,再接着是讲 this 的其他用法。

所有者(Owner)

先来看看函数 doSomething() 里的 this 究竟指向(refer to)了什么?

function doSomething() {
this.style.color = '#cc0000';
}

JavaScript的 this 总是指向正执行的函数的所有者。或者是说,它是指向函数这个对象的一种手法。

在页面中定义了 doSomething() 函数时,它的所有者是页面。确切的说是指 JavaScript 的 window 对象(全局对象)。

而 onclick 属性归属 HTML 元素所有。

这种归属谁所有的权利是 JavaScript 的 OO(面向对象)特性的结果。在 把对象作关联数组 页面中有更多信息。

------------ window --------------------------------------
| / / |
| | |
| this |
| ---------------- | |
| | HTML 元素 | <-- this ----------------- |
| ---------------- | | doSomething() | |
| | | ----------------- |
| -------------------- |
| | onclick 属性 | |
| -------------------- |
| |
----------------------------------------------------------

这里在 doSomething() 执行时,关键字 this 指向 window(窗口) ,该函数将会改动 window 的 style.color。

而 window 没有 style 这个对象,所以该函数会引发 JavaScript 的错误。

拷贝(copying)

因此,想要用好 this 就请继续往下看。像前面的例子在函数中使用的这种情况,this 指向它归属谁所有的那个 HTML 元素。

也就是说,有个函数拷贝指向 onclick 属性。 我们来看看在传统事件注册 中的情况。

element.onclick = doSomething;

函数是它整个的拷贝,指向 onclick 属性(现在变成了方法)。因此,事件处理被执行时,this 指向 HTML 元素并将改动 color。

------------ window --------------------------------------
| |
| |
| |
| ---------------- |
| | HTML 元素 | <-- this ----------------- |
| ---------------- | | doSomething() | |
| | | ----------------- |
| ----------------------- | |
| | doSomething() 的拷贝| <-- 拷贝函数 |
| ----------------------- |
| |
----------------------------------------------------------

这样我们可以拷贝函数给多个事件处理。每次 this 将指向正确的 HTML 元素:

------------ window --------------------------------------
| |
| |
| |
| ---------------- |
| | HTML 元素 | <-- this ----------------- |
| ---------------- | | doSomething() | |
| | | ----------------- |
| ----------------------- | |
| | doSomething() 的拷贝| <-- 拷贝函数 |
| ----------------------- | |
| | |
| ----------------------- | |
| | 另一个 HTML 元素 | <-- this | |
| ----------------------- | | |
| | | | |
| ----------------------- | |
| | doSomething() 的拷贝| <-- 拷贝函数 |
| ----------------------- |
| |
----------------------------------------------------------

每次函数被调用,this 指向当前所处理的事件的那个 HTML 元素( doSomething() 的拷贝“所有”)。

指向(referring)

要是用 行内事件注册 呢?

<element onclick="doSomething()">

这里没有拷贝函数,而是指向它,有什么不一样呢? 这个 onclick 属性没有包含实际函数,而只是一个函数调用。

doSomething();

上面的意思是:“到 doSomething() 那里去执行它”。在doSomething()里面,this 关键字再次指向全局 window 对象,

那么函数会返回错误的消息。

------------ window --------------------------------------
| / / |
| | |
| this |
| ---------------- | |
| | HTML 元素 | <-- this ----------------- |
| ---------------- | | doSomething() | |
| | | ----------------- |
| ----------------------- / / |
| | 到 doSomething() 那 | | |
| | 里去执行它 | ---- 指向 |
| ----------------------- 函数 |
| |
----------------------------------------------------------

不一样?

如果是用 this 去访问 HTML 元素来处理事件的话,那么必须肯定它实际是写入了 onclick 属性中。

就算它指向 HTML 元素的事件处理是已注册。如果这么做:

element.onclick = doSomething;
alert(element.onclick)

得到的是

function doSomething()
{
this.style.color = '#cc0000';
}

可以看到,this 关键字在 onclick 方法中。它指向 HTML 元素。

但是如果这么做:

<element onclick="doSomething()">
alert(element.onclick)

得到的是

function onclick()
{
doSomething()
}

这里只是指向函数 doSomething()。this 关键字不在 onclick 方法中。它没有指向 HTML 元素。

例子-拷贝

在下面示例中,this 写入 onclick 方法中:

element.onclick = function () {doSomething()}
element.attachEvent('onclick',doSomething)
<element onclick="doSomething()">

例子-指向

在下面示例中,this 指向 window:

element.onclick = function () {doSomething()}
element.attachEvent('onclick',doSomething)
<element onclick="doSomething()">

要注意上面的 attachEvent。它的缺点是微软事件注册模型 ,它创建了到该函数的指向,而且没有拷贝它。

所以有时不可能弄清楚 HTML 当前的处理事件是哪个。

结合

使用行内事件注册时,也可以把 this 发送给函数。所以可以这么用:

<element onclick="doSomething(this)">

function doSomething(obj) {
// 在事件处理中把它发送给函数
// obj 指向 HTML 元素,所以可以这么做
obj.style.color = '#cc0000';
}
分享到:
评论

相关推荐

    PPK 谈 JavaScript 的 this 关键字 [翻译]

    JavaScript的 this 总指向所运行的函数“自己本身”。也就是说,它是一种指向函数对象的方法。在页面中定义 doSomething() 函数,自己本身是指页面。也就是说,是指 JavaScript 的 window 对象(全局对象)。而 ...

    《ppk谈JavaScript》中文版pdf和原书示例源码

    ppk谈JavaScript JavaScript入门必读之书 本书全方位介绍了JavaScript,主要讨论了浏览器兼容性、可访问性、底层语法以及与HTML结构层的协同等问题。书中既包括理论性的讲解,又给出了相关的示例脚本以进行进一步...

    PPK谈JavaScript[扫描版]

    ### PPK谈JavaScript核心知识点解析 #### JavaScript简介与重要性 JavaScript是一种广泛应用于网页开发中的脚本语言,它能够使网页具有动态效果,提升用户体验。随着互联网技术的发展,JavaScript不仅在浏览器端大...

    ppk谈JavaScript.pdf

    ppk谈JavaScript这本书,由知名Web开发专家Peter-Paul Koch(ppk)撰写,深入探讨了JavaScript的核心概念和应用。ppk是一位在前端领域有着深厚造诣的专家,他的作品通常以清晰、实用著称,能够帮助读者理解...

    ppk谈JavaScript PDF

    本书全方位介绍了JavaScript,主要讨论了浏览器兼容性、...通过8个真实项目示例,介绍了JavaScript核心语言、BOM、事件处理、DOM、修改CSS样式表以及数据检索等内容。 本书适合具有一定网页开发经验的Web开发人员阅读。

    ppk谈javascript part1

    [ppk谈JavaScript].(荷)科克.扫描版

    ppk谈JavaScript.part06.rar

    4. **this关键字**:this在JavaScript中表示当前执行上下文的对象。它的值取决于函数的调用方式,可以是全局对象、对象的引用、new操作符创建的新对象或者bind方法绑定的对象。 5. **异步编程**:JavaScript是单...

    ppk谈JavaScript.part07.rar

    《ppk谈JavaScript》系列是JavaScript领域的经典读物,作者ppk(Peter-Paul Koch)是一位知名的前端开发者和浏览器兼容性专家。这部分内容是该系列的第七部分,主要聚焦于JavaScript语言的深入理解和实践应用。 ...

    [ppk谈JavaScript part4

    [ppk谈JavaScript].(荷)科克.扫描版

    [ppk谈JavaScript part2

    [ppk谈JavaScript].(荷)科克.扫描版

    [ppk谈JavaScript part3

    [ppk谈JavaScript].(荷)科克.扫描版

    ppk谈JavaScript.part01.zip

    "ppk谈JavaScript.part01.zip"很可能包含的是Ppk关于JavaScript的系列文章或教程的第一部分,它可能涵盖了JavaScript的基础知识、最佳实践以及一些Ppk的独特见解。 JavaScript的核心概念包括变量、数据类型、控制...

    ppk谈JavaScript.part02.zip

    "ppk谈JavaScript.part02.zip"可能是一个系列教程或讲座的第二部分,由ppk(Peter-Paul Koch)分享。ppk是一位知名的前端开发者,以其对浏览器兼容性和移动Web开发的深入研究而闻名。在这个部分中,他可能会继续探讨...

    ppk谈JavaScript.part03.rar

    《ppk谈JavaScript》系列是JavaScript领域的经典读物,作者ppk(Peter-Paul Koch)是一位知名的前端开发者和浏览器兼容性专家。在这个部分,我们聚焦于JavaScript的核心概念、语法以及在实际开发中的应用。 首先,...

    ppk谈JavaScript.part05.rar

    "ppk谈JavaScript"很可能是由知名Web开发者Peter-Paul Koch(通常缩写为ppk)撰写的一系列关于JavaScript技术的文章或教程的一部分。在part05中,我们可以预期讨论深入到JavaScript的核心概念和高级特性。 首先,...

    ppk谈javascript源码

    《ppk谈JavaScript源码》是一本探讨JavaScript编程精髓的著作,由知名Web开发者Peter-Paul Koch(简称ppk)撰写。在这个压缩包中,包含了书中的一些关键示例的源代码,这对于学习和理解JavaScript的实际应用非常有...

    JavaScript(ppk谈JavaScript+JavaScript语言精粹修订+Secrets of the JavaScript Ninja)

    标题中的“ppk谈JavaScript”可能指的是Peter-Paul Koch(ppk)的一本书,他在JavaScript社区中是一位知名专家,特别在移动浏览器和跨平台兼容性方面有深入研究。ppk的书籍通常会涵盖JavaScript的基础知识,以及如何...

    ppk谈javascript示例源码

    "ppk谈JavaScript"这本书深入浅出地介绍了JavaScript的核心概念和技术,为读者提供了丰富的示例,帮助理解并掌握这一语言。作者ppk,即Peter-Paul Koch,是一位在Web开发领域有着深厚造诣的专家,他的著作以其清晰的...

Global site tag (gtag.js) - Google Analytics