`
123003473
  • 浏览: 1060238 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

JavaScript的局部和全局变量

阅读更多
一直以为自己对JavaScript已经很精通了,这次却犯了一个低级错误。这个错误带来的后果就是:如果你最近用浏览器上小百合的话,发现点击左边导航菜单的链接都会打开新窗口。。。其次的后果是害我调试了一下午加晚上。。。
先是这样的,为了DOM设置属性的方便,我自己写了个方法,省得每次都setAttribute:

Net = {}; 
Net.Dom = {}; 
Net.Dom.setProperties = function(obj) 
{ 
    for(var i=1; i<arguments.length; i++) 
    { 
        if(typeof arguments[i]=="object") 
        { 
            for(name in arguments[i]) 
                obj[name] = arguments[i][name]; 
        } 
    } 
} 
  
//这样原来: 
div.setAttribute("width", "100px"); 
div.setAttribute("height", "100%"); 
...... 
//就可以写成: 
Net.Dom.setProperties(div, {width:"100px", height: "100%"});


上面的setProperties代码里面有个错误,会导致改变window的name属性。因为window是可以省略的(直接打document其实是window.document),而“for(name in arguments[i])”的表示方法浏览器会解析成“for(window.name in arguments[i])”。也就是框架的name变了,这样左边设的target自然就失效了,导致链接都以新窗口打开。改成“for(var name in arguments[i])”就好了。
因为JavaScript相对比较自由,写变量一定要注意,而且这种错误比较隐蔽,难以发现。局部变量一定要以var申明,否则是全局变量;要用全局变量时候也要注意一下命名方法,以”g_”开头或者全大写都是可行的办法。


最后我们一起复习一下JavaScript的局部变量和全局变量:

变量范围
JScript 有两种变量范围:全局和局部。如果在任何函数定义之外声明了一个变量,则该变量为全局变量,且该变量的值在整个持续范围内都可以访问和修改。如果在函数定义内声明了一个变量,则该变量为局部变量。每次执行该函数时都会创建和破坏该变量;且它不能被该函数外的任何事物访问。
像 C++ 这样的语言也有“块范围”。在这里,任何一对“{}”都定义新的范围。JScript 不支持块范围。
一个局部变量的名称可以与某个全局变量的名称相同,但这是完全不同和独立的两个变量。因此,更改一个变量的值不会影响另一个变量的值。在声明局部变量的函数内,只有该局部变量有意义。
var aCentaur = "a horse with rider,";  // aCentaur 的全局定义。 
  
// JScript 代码,为简洁起见有省略。 
function antiquities()  // 在这个函数中声明了一个局部 aCentaur 变量。 
{ 
  
// JScript 代码,为简洁起见有省略。 
var aCentaur = "A centaur is probably a mounted Scythian warrior"; 
  
// JScript 代码,为简洁起见有省略。 
   aCentaur += ", misreported; that is, ";  // 添加到局部变量。 
  
// JScript 代码,为简洁起见有省略。 
}  // 函数结束。 
  
var nothinginparticular = antiquities(); 
aCentaur += " as seen from a distance by a naive innocent."; 
  
/* 
在函数内,该变量的值为 "A centaur is probably a mounted Scythian warrior, 
misreported; that is, ";在函数外,该变量的值为这句话的其余部分: 
"a horse with rider, as seen from a distance by a naive innocent." 
*/


很重要的一点是注意变量是否是在其所属范围的开始处声明的。有时这会导致意想不到的情况
tweak(); 
var aNumber = 100; 
function tweak()  { 
var newThing = 0;  // 显式声明 newThing 变量。 
  
    // 本语句将未定义的变量赋给 newThing,因为已有名为 aNumber 的局部变量。 
    newThing = aNumber; 
  
    //下一条语句将值 42 赋给局部的 aNumber。aNumber = 42; 
if (false)  { 
    var aNumber;  // 该语句永远不会执行。 
    aNumber = 123;  //  该语句永远不会执行。 
    }  // 条件语句结束。 
  
}  // 该函数定义结束。

当 JScript 运行函数时,首先查找所有的变量声明,
var someVariable;
并以未定义的初始值创建变量。如果变量被声明时有值,
var someVariable = “something”;
那么该变量仍以未定义的值初始化,并且只有在运行了声明行时才被声明值取代,假如曾经被声明过。
JScript 在运行代码前处理变量声明,所以声明是位于一个条件块中还是其他某些结构中无关紧要。JScript 找到所有的变量后立即运行函数中的代码。如果变量是在函数中显式声明的 — 也就是说,如果它出现于赋值表达式的左边但没有用 var 声明 — 那么将把它创建为全局变量。
分享到:
评论

相关推荐

    JavaScript声明全局变量访问方法

    - 尽量减少全局变量的使用,优先考虑局部变量和作用域闭包。 - 使用模块系统(如CommonJS、ES6模块)管理变量,以防止全局空间的污染。 - 使用`const`声明常量,避免不必要的修改。 - 使用立即执行函数表达式...

    浅谈JavaScript的全局变量与局部变量_.docx

    总的来说,理解JavaScript的全局变量和局部变量的规则,有助于编写更安全、更易于维护的代码。正确使用作用域,避免全局变量滥用,可以显著提高代码的可读性和可靠性。在编写JavaScript代码时,应该始终关注变量的...

    javascript中局部变量和全局变量的区别详解

    在JavaScript编程语言中,变量可以分为局部变量和全局变量两种类型,它们在作用域以及生命周期等方面有着显著的区别。 首先,全局变量的作用域是整个JavaScript代码块,包括所有函数和代码块内部。全局变量被声明在...

    javascript全局变量说明示例

    看看有帮助,全局变量,与局部变量的差异!

    javascript 用局部变量来代替全局变量第1/2页

    为了提升性能,减少潜在的命名冲突,并且遵循最佳实践,推荐在JavaScript中尽可能使用局部变量来代替全局变量。这一点在众多开发者的共识中已经成为一个基本规则。Nicholas C. Zakas是这一建议的早期倡导者之一,他...

    浅谈JavaScript的全局变量与局部变量

    JavaScript中的变量管理是一个关键概念,理解全局变量与局部变量的区别...在编写JavaScript代码时,应尽可能减少全局变量的使用,以降低命名冲突的风险,并利用局部变量来限制变量的作用范围,使代码更易于理解和调试。

    JavaScript进阶:JS的全局变量和全局函数.docx

    全局变量和全局函数是JavaScript中两个基础且重要的概念。 全局变量是在函数外部声明的变量,可以在整个程序的任何地方被访问。它们在程序开始执行时被创建,并在整个程序生命周期内存在。JavaScript的全局变量有三...

    基于JavaScript 声明全局变量的三种方式详解

    在JavaScript中,声明全局变量有三种主要方式,每种方式都有其特点和适用场景。以下是详细的分析: 1. 显式声明:使用`var`关键字 这是最常见的方式,通过在函数外部或脚本的顶部使用`var`关键字声明变量,使其成为...

    python 零基础学习篇web前端开发基础JavaScript基础5 全局变量和局部变量 .mp4

    python 零基础学习篇

    JS全局变量和局部变量最新解析

    总结来说,理解JavaScript中的全局变量和局部变量,以及`var`和`this`的关键字用法,对于编写高效、无错的代码至关重要。在实际开发中,应避免过多使用全局变量以减少命名冲突和内存占用,同时合理利用局部变量和...

    探讨JavaScript中声明全局变量三种方式的异同

    在探讨JavaScript中声明全局...总结来说,虽然在JavaScript中声明全局变量有多种方式,但开发者应根据实际需求和预期的浏览器兼容性选择合适的方法。理解每种方式的差异对于编写高质量的JavaScript代码是至关重要的。

    Python全局变量-函数内部不允许修改局部变量的值

    Python还被语言流行指数的编译器Tiobe将它被评为最受欢迎的编程语言,20多年来首次将Python置于Java、C和JavaScript之上,真的非常荣幸了. 自从20世纪90年代初Python语言诞生至2022年,它已被逐渐广泛应用于系统...

    浅析JavaScript预编译和暗示全局变量

    1. 暗示全局变量 未声明的变量称为暗示全局变量。 var a = 1; //函数体外声明的变量称为全局变量 b = 2; // 无论函数体外或函数体内未声明的变量都称为暗示全局变量 function fn() { var c = 3; //函数体内声明的...

    JavaScript程序设计-变量作用域.pdf

    本文将深入探讨JavaScript中的全局变量、局部变量、变量提升、词法作用域以及作用域链。 1.1 全局变量与局部变量 全局变量在整个程序中都可访问,即使在函数内部定义,它们也会成为全局变量,除非在函数内部重新...

    基于JavaScript的变量作用域的辨析.pdf

    在JavaScript中,有全局变量和局部变量之分,其作用域由函数约束。全局变量是定义在所有函数体之外,其作用域是所有函数;而局部变量是定义在函数体之内,只对该函数是可见的,而对其他函数则是不 可见的。在构建...

    Javascript学习之谈谈JS的全局变量跟局部变量(推荐)

    JavaScript中的全局变量和局部变量是编程中至关重要的概念,它们决定了变量的作用范围和生命周期。本文将深入探讨这两种变量类型,并通过实例解析它们的工作原理。 首先,全局变量是在函数外部定义的变量,它在整个...

    javascript变量作用域

    在 JavaScript 中,函数体内部的局部变量的优先级比同名的全局变量高。这是因为 JavaScript 会优先查找当前作用域中的变量,而不是全局变量。 JavaScript 还没有块级作用域,这意味着在 if 语句、for 循环、while ...

    JavaScript防止全局变量污染的方法总结

    然而,由于JavaScript的全局变量机制,不恰当的变量使用容易导致全局变量污染,从而影响代码的可维护性和稳定性。以下是防止全局变量污染的一些方法和注意事项: 1. **命名空间**: 创建一个全局命名空间对象,将...

Global site tag (gtag.js) - Google Analytics