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>

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

目录
相关文章
|
18天前
|
JavaScript 前端开发
JavaScript如何判断变量undefined
JavaScript如何判断变量undefined
|
19天前
|
存储 前端开发 JavaScript
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
本文介绍了JavaScript变量的声明和使用、标识符的命名规则、如何获取和操作HTML元素,以及JavaScript的鼠标事件处理,通过示例代码展示了这些基础知识点在实际开发中的应用。
32 2
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
|
19天前
|
JavaScript 前端开发
js 变量作用域与解构赋值| 22
js 变量作用域与解构赋值| 22
|
4天前
|
JavaScript 前端开发
什么是JavaScript变量?
什么是JavaScript变量?
13 0
|
1月前
|
存储 JavaScript 前端开发
|
2月前
|
JavaScript 前端开发
揭秘JavaScript变量的三大守护神:从var到let,再到const,究竟隐藏了哪些秘密?
【8月更文挑战第22天】在JavaScript中,`var`、`let`和`const`用于声明变量,但各有特点。`var`有函数作用域并会被提升至作用域顶部。`let`提供块级作用域且存在暂时性死区,不允许提前访问。`const`同样拥有块级作用域,用于声明常量,一旦初始化便不可改变。现代开发倾向于使用`let`和`const`以获得更清晰的作用域控制和避免潜在错误。
28 0
|
2月前
|
JavaScript 前端开发
揭开JavaScript变量作用域与链的神秘面纱:你的代码为何出错?数据类型转换背后的惊人秘密!
【8月更文挑战第22天】JavaScript是Web开发的核心,了解其变量作用域、作用域链及数据类型转换至关重要。作用域定义变量的可见性与生命周期,分为全局与局部;作用域链确保变量按链式顺序查找;数据类型包括原始与对象类型,可通过显式或隐式方式进行转换。这些概念直接影响代码结构与程序运行效果。通过具体示例,如变量访问示例、闭包实现计数器功能、以及动态表单验证的应用,我们能更好地掌握这些关键概念及其实践意义。
29 0
|
3月前
|
设计模式 JavaScript 前端开发
JS 代码变量和函数的正确写法
JS 代码变量和函数的正确写法
43 3
|
2月前
|
JavaScript 前端开发
JavaScript声明变量的几种方式
JavaScript声明变量的几种方式
24 0
|
3月前
|
JavaScript
js export 对外输出常量、变量和函数
js export 对外输出常量、变量和函数
76 5