javascript中的变量

简介:
问题:
    在JavaScript脚本中创建一个全局或局部变量。

解决方案:
    使用var关键字来定义每个变量的第一个实例(instance)。如下所示:
    var myVar = someValue;

    定义在函数之外的变量都是全局变量,页面上的脚本,包括那些函数内部的脚本,都可以对全局变量进行读写。
    在函数内部使用var定义的变量为局部变量,只有函数内部的脚本可以访问它们,其名称可以与全局变量名称相同。

    注意:在C等语言得到支持的“块范围”,JavaScript不支持。
    如果在var语句中没有初始化变量,变量自动取 JavaScript值undefined。另外,尽管并不安全,但声明语句中忽略var关键字是合法的JavaScript语法,这时的变量为全局变量,所以在函数内部要注意,尽量用var关键字来声明变量,否则很有可能操作的是一个已经声明的全局变量,增大调试和维护的难度。

    作用域是一个重要的概念。对于一个全局变量,不仅当前window/frame的脚本可以访问,同一个域和服务器的其它window/frame的脚本也可以对其进行访问,这要通过对变量所在window/frame的引用(reference)。例如,要访问subwin窗体的全局变量globalVar,可用subwin.globalVar; 

    JavaScript在为变量赋值的时候有两种方式:“按值”和”按引用“,这有数据的类型决定。如果数据为真正的对象(如DOM对象,数组,自定义对象,函数),那么变量将持有一个该对象的引用。如果数据为简单值类型(如string, number, Boolean),变量将持有该数据的副本。

    注意:变量是否是在其所属范围的开始处声明的。有时这会导致意想不到的情况。看下面这段示例:
     var  aNumber  =   100 ;
    
function  varDeclaration()
    {
        
var  newNumber  =  aNumber;
        window.alert(newNumber);
        
if ( false )
        {
            
// 这行代码永远不会执行
             var  aNumber  =   10 ;
        }
    }

    此处的newNumber值是什么?按正常思路,局部变量aNumber的声明语句不会执行,那么赋给newNumber的变量aNumber应当是全局变量aNumber,其值为100,但事实上却是undefined。原因是:JavaScript在运行代码前处理变量声明,所以声明是位于一个条件块中还是其他某些结构中无关紧要。JavaScript找到所有的变量后立即运行函数中的代码,在给newNumber赋值的时候,局部变量aNumber已经得到声明,但还没初始化,此时其值为undefined。

    参考:
    (Oreilly)Java Script And Dhtml Cookbook

    JScript参考手册


本文转自一个程序员的自省博客园博客,原文链接:http://www.cnblogs.com/anderslly/archive/2006/10/15/jsvariable.html,如需转载请自行联系原作者。

目录
相关文章
|
3月前
|
JavaScript 前端开发
JavaScript如何判断变量undefined
JavaScript如何判断变量undefined
|
3月前
|
JavaScript 前端开发
JavaScript基础知识-变量的声明提前
关于JavaScript变量声明提前特性的基础知识介绍。
46 0
JavaScript基础知识-变量的声明提前
|
22天前
|
前端开发 JavaScript
如何在 JavaScript 中访问和修改 CSS 变量?
【10月更文挑战第28天】通过以上方法,可以在JavaScript中灵活地访问和修改CSS变量,从而实现根据用户交互、页面状态等动态地改变页面样式,为网页添加更多的交互性和动态效果。在实际应用中,可以根据具体的需求和场景选择合适的方法来操作CSS变量。
|
22天前
|
前端开发 JavaScript 数据处理
CSS 变量的作用域和 JavaScript 变量的作用域有什么不同?
【10月更文挑战第28天】CSS变量和JavaScript变量虽然都有各自的作用域概念,但由于它们所属的语言和应用场景不同,其作用域的定义、范围、覆盖规则以及与其他语言特性的交互方式等方面都存在明显的差异。理解这些差异有助于更好地在Web开发中分别运用它们来实现预期的页面效果和功能逻辑。
|
22天前
|
前端开发 JavaScript UED
如何使用 JavaScript 动态修改 CSS 变量的值?
【10月更文挑战第28天】使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。
|
3月前
|
存储 前端开发 JavaScript
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
本文介绍了JavaScript变量的声明和使用、标识符的命名规则、如何获取和操作HTML元素,以及JavaScript的鼠标事件处理,通过示例代码展示了这些基础知识点在实际开发中的应用。
43 2
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
|
2月前
|
JavaScript 前端开发
局部 JavaScript 变量
JavaScript 中,函数内部使用 `var` 声明的变量为局部变量,仅在函数内可见,函数执行完毕后被删除。全局变量则在函数外部声明,整个页面的脚本和函数均可访问,页面关闭后才被删除。未声明的变量赋值会自动成为 `window` 对象的属性,且在非严格模式下可被删除。
|
3月前
|
JavaScript 前端开发
js 变量作用域与解构赋值| 22
js 变量作用域与解构赋值| 22
|
2月前
|
JavaScript 前端开发
什么是JavaScript变量?
什么是JavaScript变量?
37 0
|
3月前
|
存储 JavaScript 前端开发
下一篇
无影云桌面