JavaScript基础知识-变量的声明提前

简介: 关于JavaScript变量声明提前特性的基础知识介绍。

作者:尹正杰
版权声明:原创作品,谢绝转载!否则将追究法律责任。

一.JavaScript源代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>变量的声明提前</title>

    <script type="text/javascript">
        console.log("windows.x  = %s",window.x)
        /**
         *  变量的声明提前:
         *      使用var关键字声明的变量,会在所有的代码执行之前被声明(但是不会赋值)。
         *      但是如果声明变量时不使用var关键字,则变量不会被声明提前。
         *
         *  案例展示:
         *      (1)var x = 100,其实等效于先执行了"var x;"但并未赋值,因此上面一行代码打印的值为"undefined";
         *      (2)其实本行就执行了"x = 100",因为"var x;"变量提前声明已经在运行代码之前被执行啦~本行仅仅是一个赋值操作;
         *      (3)由于本行执行了赋值操作,因此下面一行代码打印的值为"100"。
         */
        var x = 100;
        console.log("windows.x  = %s",window.x)

        /**
         *  函数的声明提前:
         *      (1)使用函数声明形式创建的函数会在所有代码执行之前就被创建。
         *      (2)使用函数表达式创建的函数,不会被提前声明函数对象,所以不能在声明前调用。
         */

        foo()  // 该行代码可以正常执行,因为浏览器会提前声明函数对象。
        bar()  // 该行代码会抛出异常,因为浏览器不会提前创建函数对象。

        // 使用函数声明形式创建函数,会被提前创建,因此该函数无论你写在那里
        function  foo() {
            console.log("In foo function...")
        }

        // 使用函数表达式形式创建函数,不会被提前创建函数,但会提前声明bar这个变量(默认值为"undefined")。
        var bar = function () {
            console.log("In bar function...")
        }

    </script>
</head>
<body>

</body>
</html>

二.浏览器打开以上代码渲染结果

目录
相关文章
|
6天前
|
JavaScript 前端开发 开发者
JavaScript基础——JavaScript变量名称命名规范
JavaScript变量命名规范是编写高质量代码的重要部分。通过遵循基本规则、使用常见命名约定并应用最佳实践,可以提高代码的可读性和可维护性。希望本文能帮助开发者在日常编程中更好地理解和应用JavaScript变量命名规范,从而编写出更清晰、更可靠的代码。
31 11
|
6月前
|
JavaScript 前端开发
JavaScript如何判断变量undefined
JavaScript如何判断变量undefined
|
2月前
|
JavaScript 前端开发 容器
盘点JavaScript中所有声明变量的方式及特性
本文详细介绍了JavaScript中变量定义的多种方式,包括传统的`var`、`let`和`const`,以及通过`this`、`window`、`top`等对象定义变量的方法。每种方式都有其独特的语法和特性,并附有代码示例说明。推荐使用`let`和`const`以避免作用域和提升问题,谨慎使用`window`和`top`定义全局变量,不建议使用隐式全局变量。掌握这些定义方式有助于编写更健壮的JS代码。
49 11
|
4月前
|
前端开发 JavaScript
如何在 JavaScript 中访问和修改 CSS 变量?
【10月更文挑战第28天】通过以上方法,可以在JavaScript中灵活地访问和修改CSS变量,从而实现根据用户交互、页面状态等动态地改变页面样式,为网页添加更多的交互性和动态效果。在实际应用中,可以根据具体的需求和场景选择合适的方法来操作CSS变量。
144 12
|
4月前
|
前端开发 JavaScript 数据处理
CSS 变量的作用域和 JavaScript 变量的作用域有什么不同?
【10月更文挑战第28天】CSS变量和JavaScript变量虽然都有各自的作用域概念,但由于它们所属的语言和应用场景不同,其作用域的定义、范围、覆盖规则以及与其他语言特性的交互方式等方面都存在明显的差异。理解这些差异有助于更好地在Web开发中分别运用它们来实现预期的页面效果和功能逻辑。
|
4月前
|
前端开发 JavaScript UED
如何使用 JavaScript 动态修改 CSS 变量的值?
【10月更文挑战第28天】使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。
|
6月前
|
存储 前端开发 JavaScript
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
本文介绍了JavaScript变量的声明和使用、标识符的命名规则、如何获取和操作HTML元素,以及JavaScript的鼠标事件处理,通过示例代码展示了这些基础知识点在实际开发中的应用。
67 2
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
|
5月前
|
JavaScript 前端开发
局部 JavaScript 变量
JavaScript 中,函数内部使用 `var` 声明的变量为局部变量,仅在函数内可见,函数执行完毕后被删除。全局变量则在函数外部声明,整个页面的脚本和函数均可访问,页面关闭后才被删除。未声明的变量赋值会自动成为 `window` 对象的属性,且在非严格模式下可被删除。
|
6月前
|
JavaScript 前端开发
js 变量作用域与解构赋值| 22
js 变量作用域与解构赋值| 22
|
5月前
|
JavaScript 前端开发
什么是JavaScript变量?
什么是JavaScript变量?
56 0

热门文章

最新文章