`
japankn
  • 浏览: 213468 次
  • 性别: Icon_minigender_1
  • 来自: 广西
社区版块
存档分类
最新评论

JavaScript的局部和全局变量

阅读更多

先是这样的,为了DOM设置属性的方便,我自己写了个方法,省得每次都setAttribute:

  1. Net = {};
  2. Net.Dom = {};
  3. Net.Dom.setProperties = function(obj)
  4. {
  5.     for(var i=1; i<arguments.length; i++)
  6.     {
  7.         if(typeof arguments[i]=="object")
  8.         {
  9.             for(name in arguments[i])
  10.                 obj[name] = arguments[i][name];
  11.         }
  12.     }
  13. }
  14.  
  15. //这样原来:
  16. div.setAttribute("width", "100px");
  17. div.setAttribute("height", "100%");
  18. ......
  19. //就可以写成:
  20. 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 不支持块范围。

一个局部变量的名称可以与某个全局变量的名称相同,但这是完全不同和独立的两个变量。因此,更改一个变量的值不会影响另一个变量的值。在声明局部变量的函数内,只有该局部变量有意义。

  1. var aCentaur = "a horse with rider,"// aCentaur 的全局定义。
  2.  
  3. // JScript 代码,为简洁起见有省略。
  4. function antiquities()  // 在这个函数中声明了一个局部 aCentaur 变量。
  5. {
  6.  
  7. // JScript 代码,为简洁起见有省略。
  8. var aCentaur = "A centaur is probably a mounted Scythian warrior";
  9.  
  10. // JScript 代码,为简洁起见有省略。
  11.    aCentaur += ", misreported; that is, "// 添加到局部变量。
  12.  
  13. // JScript 代码,为简洁起见有省略。
  14. }  // 函数结束。
  15.  
  16. var nothinginparticular = antiquities();
  17. aCentaur += " as seen from a distance by a naive innocent.";
  18.  
  19. /*
  20. 在函数内,该变量的值为 "A centaur is probably a mounted Scythian warrior,
  21. misreported; that is, ";在函数外,该变量的值为这句话的其余部分:
  22. "a horse with rider, as seen from a distance by a naive innocent."
  23. */

很重要的一点是注意变量是否是在其所属范围的开始处声明的。有时这会导致意想不到的情况。

  1. tweak();
  2. var aNumber = 100;
  3. function tweak()  {
  4. var newThing = 0// 显式声明 newThing 变量。
  5.  
  6.     // 本语句将未定义的变量赋给 newThing,因为已有名为 aNumber 的局部变量。
  7.     newThing = aNumber;
  8.  
  9.     //下一条语句将值 42 赋给局部的 aNumber。aNumber = 42;
  10. if (false)  {
  11.     var aNumber// 该语句永远不会执行。
  12.     aNumber = 123//  该语句永远不会执行。
  13.     }  // 条件语句结束。
  14.  
  15. }  // 该函数定义结束。

当 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