JavaScript 作用域、变量提升和严格模式

本文详细介绍了JavaScript中的作用域,包括全局作用域和函数作用域,以及变量提升的概念和初始化问题。强调了全局变量在任何地方都可访问,而函数作用域独立且按需创建。还提到了变量提升的特性,即声明被提升到顶部,但初始化不会。最后,讨论了严格模式在消除JavaScript某些不严谨行为上的重要性,并建议开发者尽量使用。
摘要由CSDN通过智能技术生成

作用域

全局作用域

直接编写在script标签内的代码,都在全局作用域。其实就是在函数外部定义的。全局作用域在页面打开时创建,在页面关闭时销毁。在全局作用域有一个全局对象window,我们可以直接使用它。而且所有的全局变量都是window的属性,全局函数都是window的方法。全局变量在任何地方都可以访问。

var x=5;
console.log(x);
console.log(window.x);
func();
function func(){
 console.log(x);
}

在这里插入图片描述

函数作用域

调用函数时创建函数作用域,函数结束后销毁函数作用域。每一个函数的作用域都是独立的。在函数内使用变量会先在自身作用域内查找,如果没找到就去上一级作用域查找……

var x=5;
func();
function func(){
    alert(x);
}

在这里插入图片描述

        var x=5;
        func();
        function func(){
            var x=10;
            alert(x);
        }

在这里插入图片描述

变量提升

在js中,函数及变量的声明都将被提升到最顶部,所以变量和函数可以先使用再声明。所以下面两种写法的效果是一样的(只测试变量提升,函数就不测试了):

x=5;
alert(5);
var x;
var x;
x=5;
alert(5);

在这里插入图片描述

初始化问题

但是这里有一个隐藏的问题,就是变量的初始化并不会随着声明一起提升。举个例子:

var x=5;
alert(x);

在这里插入图片描述

alert(x);
var x=5;

在这里插入图片描述
第一种情况很好理解,第二种情况是因为 x x x的声明被提前了,但是初始化并没有被提前,所以在执行 a l e r t ( x ) alert(x) alert(x)时它的值是 u n d e f i n e d undefined undefined

严格模式

JavaScript 严格模式(strict mode)即在严格的条件下运行。它不是一条语句,但是是一个字面量表达式,在 JavaScript 旧版本中会被忽略。“use strict” 的目的是指定代码在严格条件下执行。严格模式下你不能使用未声明的变量。

//"use strict";
x=5;
alert(x);

在这里插入图片描述

"use strict";
x=5;
alert(x);

在这里插入图片描述
我们应该尽量使用严格模式,它消除了Javascript语法的一些不合理、不严谨之处,减少一些怪异行为。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值