`
flare
  • 浏览: 124690 次
  • 性别: Icon_minigender_1
  • 来自: 天尽头
社区版块
存档分类
最新评论

小心使用this

阅读更多
http://www.cnblogs.com/zhengchuyu/archive/2008/07/22/1248286.html

有种流行的说法:JavaScript是基于对象和事件驱动的。应该怎样理解“基于对象”的意思呢?

《精通JavaScript》告诉我们,对象是JavaScript的基础,甚至说“JavaScript这门语言就是完全面向对象的”。



我不知道应该怎样评判这样的说法,JavaScript确实有面向对象的特性,但是他的表现形式却和其他面向对象编程语言大相径庭。





在谈JavaScript的面向对象之前,我想先说说JavaScript的作用域问题。我想只有搞清楚这个问题,才能更好地理解接下来的内容。我将会用自己的理解将JavaScript中的面向对象特性与一般面向对象程序设计语言(Java/C++等)的一些称谓对应起来。





首先理清两个问题:

1.什么是全局变量?

JavaScript中的全局变量实际上指的是window对象下的对象属性。

2.作用域划分。

JavaScript中的作用域是基于上下文,以函数进行划分的,而不是由块(block)划分的。



接下来看一个例子(原例来自《精通JavaScript》,有改动):
<script type="text/javascript">

// 设置全局变量foo,并置为“test”
var foo = "test";

if ( true )
{
    // 注意:现在还在全局作用域中
    var foo = "new test";
}

// 如我们所见,现在foo等于'new test'了
alert( foo );

// 创建一个会修改变量foo的新函数
function test()
{
    //函数内部定义变量不影响全局变量
    var foo = "old test";
    //隐式定义全局变量
    val = 'hello!';
}

// 然而在调用test函数时,foo只在函数作用域内起作用
test();

// 确认foo还是等于'new test'
alert( foo );

// 全局变量实际是window下的属性
alert( window.foo );

// 函数内部隐式定义的全局变量
alert(val);

</script>



现在你大概对JavaScript的作用域有了一个初步的理解。

要强调的两点是:

1.在同一作用域中,JavaScript是允许变量的重复定义的,并且后一个定义将覆盖前一个定义。

2.函数内部如果不加关键字var而定义的变量,默认为全局变量。




这篇blog中的例子需要引起注意的是,如果把函数修改为以下的方式结果会完全不同
function test()
{
    //函数内部定义变量不影响全局变量
   this.test = "old test";
    //隐式定义全局变量
    val = 'hello!';
}
分享到:
评论

相关推荐

    详解javascript中的this对象.pdf

    ## JavaScript 中的 `this` 对象详解 JavaScript 是一种基于对象和事件驱动的动态类型...同时,需要注意的是,`this` 的动态绑定特性也可能带来一些陷阱,所以在编写代码时要格外小心,确保正确理解和使用 `this`。

    Javascript中的this,bind和that使用实例

    在JavaScript中,`this`关键字的使用可以非常灵活,但同时也需要小心处理,特别是考虑到它的动态性。通过本文章的介绍,我们可以更好地理解`this`、`bind()`以及如何使用`that`来管理函数的执行上下文,进而写出更加...

    pkt_cls.rar_This Is Now

    不过,如果不小心使用,宏可能会导致代码难以理解和调试。 3. **MIPS架构**:MIPS(Microprocessor without Interlocked Pipeline Stages)是一种精简指令集计算机(RISC)架构,以其简洁高效的指令集设计而闻名。...

    浅谈JavaScript中this的指向问题

    这可能会导致一些问题,比如不小心将一个全局函数用作普通函数调用,而其内部代码使用了this,那么就可能出现错误。 此外,还有一个特殊情况,那就是定时器函数(如setTimeout或setInterval中的回调函数)。在这些...

    javascript中this做事件参数相关问题解答

    在JavaScript编程中,`this`关键字是一个经常被误解和误用的概念。特别是在处理事件时,它的行为和含义...记住,在处理HTML标签属性中`this`的使用时,需要格外小心,因为`this`并不会在这些属性中自动获得预期的行为。

    stricterify:Browserify 转换以在最初没有它的模块上添加“使用严格”。 小心使用。 如果不是全球性的更好

    小心使用。 如果不是全球性的更好 概述 此转换将变成: var someFunc = function ( ) { } ; module . exports = someFunc ; 进入这个: 'use strict' ; var someFunc = function ( ) { } ; module . exports =...

    用于简单的反射对象的属性,字段,方法的方式

    不区分public和private都可以反射,请小心使用 * 4....暂时不支持泛型方法,in和out参数的方法,有好的建议可以联系我 * 5....中文注释已经比较全面 * * 有建议或者BUG可以联系:fttl_398@126.com * 所有提供建议...

    C#无边框窗体制作小心得

    this.Label.MouseMove += new System.Windows.Forms.MouseEventHandler(this.Label_MouseMove); this.Label.MouseDown += new System.Windows.Forms.MouseEventHandler(this.Label_MouseDown); this.Label....

    js this 绑定机制深入详解

    如果不小心,可能会导致意外的结果,因为`this`的绑定可能会丢失。 ```javascript function foo() { console.log(this.a); } var obj = {a: 2, foo: foo}; var bar = obj.foo; bar(); // 输出 "undefined",...

    js代码-setTimeout this指向问题

    - 当`this`的值依赖于调用方式时,使用`setTimeout`或其他异步方法需要特别小心,以确保`this`的正确绑定。 - 在使用`setTimeout`时,避免直接传递方法,而应使用箭头函数或`.bind`来固定`this`的指向。 - 考虑...

    clickthis.py

    通过python的文件生成与死循环,让这些以十六进制为名字生成的文本格式的文件无限生成,致使你的电脑内存爆炸,如果不小心运行了click.py,请按ctrl+c停止终端或者立即关闭,谢谢!

    JavaScript函数中的this四种绑定形式

    【故事】有一个年轻人叫”迪斯”(this),有一天,迪斯不小心穿越到一个叫 “伽瓦斯克利”(javascript)的 异世界,此时此刻迪斯身无分文, 他首先要做的事情就是——找到他的住宿的地方——调用函数的对象 ...

    【javascript】函数中的this的四种绑定形式

    )【故事】有一个年轻人叫"迪斯"(this),有一天,迪斯不小心穿越到一个叫“伽瓦斯克利”(javascript)的异世界,此时此刻迪斯身无分文,他首先要做的事情就是——找到他的住宿的地方——调用函数的对象【故事——...

    三年级上册英语一课一练Module8Unit1ThisisSamx27sbook.外研社学习.pdf

    总的来说,这个单元的学习目标是让学生能够正确使用"This is"结构来介绍物品,并理解所有格形式,同时增强他们的词汇量和语言运用能力。通过这些练习,学生可以巩固课堂上学到的知识,并提升英语听说读写各方面的...

    Java中Split的用法及注意

    需要注意的是,在使用 Split 方法时,需要小心正则表达式中的特殊字符。例如,在示例 5 中,我们使用竖线 (`|`) 作为正则表达式,但是竖线在正则表达式中有特殊的意义,所以我们需要使用转义字符 (`\\`) 来处理。...

    This is CS50's Library for C..zip

    10. **动态内存管理**:动态内存分配在C语言中需要特别小心,库可能提供了如`malloc_check()`这样的函数,确保内存分配成功并检查内存泄漏。 在使用CS50的C库时,应确保了解每个函数的工作原理,因为虽然它们简化了...

    scope-to-this-vscode:VSCode扩展的范围

    适用范围 :bullseye: 像在Visual Studio中一样,资源管理器上下文菜单中的“此范围”功能。 让您专注于重要的事情。 已知的问题 :bug: 为了确定范围,我们在settings.json配置文件中使用... 因此,在提交时要小心...

    前端大厂最新面试题-controlled_Uncontrolled.docx

    然而,如果不小心处理,可能会导致组件的状态和用户输入不一致。 Uncontrolled 组件 Uncontrolled 组件是指组件的状态不完全受外部控制的组件,组件的值可以由用户输入决定。在 Uncontrolled 组件中,组件的状态...

Global site tag (gtag.js) - Google Analytics