首页 > 其他分享 >js变量提升知识点

js变量提升知识点

时间:2023-03-04 11:35:05浏览次数:37  
标签:知识点 undefined 函数 js var foo Hello 变量

JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部:

'use strict';

function foo() {
    var x = 'Hello, ' + y;
    console.log(x);
    var y = 'Bob';
}

foo(); //Hello, undefined

为什么会打印出undefined?
虽然是strict模式,但语句var x = 'Hello, ' + y;并不报错,原因是变量y在稍后申明了。但是console.log显示Hello, undefined,说明变量y的值为undefined。这正是因为JavaScript引擎自动提升了变量y的声明,但不会提升变量y的赋值
对于foo函数,avaScript引擎看到的代码相当于:

function foo() {
    var y; // 提升变量y的申明,此时y为undefined
    var x = 'Hello, ' + y;
    console.log(x);
    y = 'Bob';
}

由于JavaScript的这一怪异的“特性”,我们在函数内部定义变量时,请严格遵守“在函数内部首先申明所有变量”这一规则。最常见的做法是用一个var申明函数内部用到的所有变量,当然有了let与const之后就不会出现这种问题了!

标签:知识点,undefined,函数,js,var,foo,Hello,变量
From: https://www.cnblogs.com/gdluck/p/17177933.html

相关文章