美文网首页
深入理解JavaScript之变量提升

深入理解JavaScript之变量提升

作者: LXJ回忆的夏天 | 来源:发表于2020-01-09 00:08 被阅读0次

变量提升

原理:JS引擎的工作方式是先解析代码,获取所有被声明的变量;然后在运行。JS代码自上而下执行之前,浏览器首先会把所有带 “VAR”/“FUNCTION” 关键词的进行提前 “声明” 或者 “定义” ,这种预先处理机制称之为 “变量提升”。

console.log(a, b);//undefined undefined
var a = 12,
    b = 12;

function fn() {
    console.log(a, b);//=>undefined 12
    var a = b = 13;
    console.log(a, b);//=>13 13
}

fn();
console.log(a, b);//=>12 13
  • undefined undefined:首先输出这个结果是因为变量提升,即前三行变成
var a;
var b;
console.log(a,b);//undefined undefined
a = 12;
b = 12;
  • undefined 12:接下来执行函数fn(fn一开始也被执行了变量提升,只不过函数中存储的都是字符串而已),对fn内部进行分析,即内部代码变成:
var a;
console.log(a,b);//undefined 12
a = 13;
b = 13; //不加var的本质是WIN的属性,即相当于window.b = 13; 
console.log(a,b);//13 13

一开始b在fn内部找不到,便会开始往上一层找,找到了全局的b,于是b输出12。

当经过var a = b = 13; 后,b被赋值为13,于是输出先从函数内部找b,找到了b=13,第二次输出b为13。(!同时,最先定义的全局变量b = 12也被赋值为13,故最后的b也等于13)

私有作用域中带var和不带var的区别:

  1. 带var的在私有作用于变量提升阶段,都声明为私有变量,和外界没有任何的关系
  2. 不带var不是私有变量,会向它的上级作用于查找,一直找到window为止(这种查找机制叫做:“作用域链”),也就是在私有作用域中操作的这个非私有变量,是一直操作别人的

只对等号左边进行变量提升

sum();
fn();// Uncaught TypeError: fn is not a function 

//=>匿名函数之函数表达式
var fn = function(){
    console.log('fn');
}//=>代码执行到此处会把函数值赋值给fn

//=>普通的函数
function sum(){
    console.log('sum');
}

条件判断下的变量提升

/*
 * 在当前作用域下,不管条件是否成立都要进行变量提升
 *   =>带VAR的还是只声明
 *   =>带FUNCTION的在老版本浏览器渲染机制下,声明和定义都处理,但是为了迎合ES6中的块级作用 
 *     域,新版浏览器对于函数(在条件判断中的函数),
 *     不管条件是否成立,都只是先声明,没有定义,类似于var
 */
console.log(a);//undefined
if(1 === 2){
   var a = 3;
}
console.log(a);//undefined

重名问题的处理

fn();//=>4
function fn() {console.log(1);}
fn();//=>4
function fn() {console.log(2);}
fn();//=>4
var fn=100;//=>带VAR的在提升阶段只把声明处理了,赋值操作没有处理,所以在代码执行的时候需要完成赋值 FN=100
fn();//=>100() Uncaught TypeError: fn is not a function
function fn() {console.log(3);}
fn();
function fn() {console.log(4);}
fn();

带VAR和FUNCTION关键字声明相同的名字,这种也算是重名了(其实是一个FN,只是存储值的类型不一样)
关于重名的处理:如果名字重复了,不会重新的声明,但是会重新的定义(重新赋值)[不管是变量提升还是代码执行阶段皆是如此]

相关文章

  • 变量对象

    参考 JavaScript深入之变量对象深入理解JavaScript系列(12):变量对象(Variable Ob...

  • 深入理解JavaScript之变量提升

    变量提升 原理:JS引擎的工作方式是先解析代码,获取所有被声明的变量;然后在运行。JS代码自上而下执行之前,浏览器...

  • 深入理解 JavaScript 执行上下文和执行栈

    深入理解 JavaScript 执行上下文和执行栈 函数上下文有变量提升的概念:但提升的只是声明 联系:上下文环境...

  • javascript的变量声明和函数提升

    要理解javascript的变量声明和函数提升,重要的是理解浏览器对javascript代码的处理过程。 包括变量...

  • 精品技术贴汇总

    about 执行上下文 深入理解JavaScript执行上下文、函数堆栈、提升的概念 JavaScript深入之变...

  • 2018-07-11

    深入理解闭包: 一、变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域。 变量的作用域无非...

  • 深入Js之我是如何搞懂作用域和闭包的

    写在前面 理解作用域之前,我们需要先了解 JavaScript 的执行机制、调用栈和变量提升等知识点。如果想要深入...

  • 执行上下文

    深入理解JavaScript执行上下文、函数堆栈、提升的概念 解密 JavaScript 执行上下文

  • 快速理解javascript变量提升

    先看一个简单的例子: 结果很明显,打印出Hello World另外一个例子来了: 结果有点意外,打印的是undef...

  • 如何理解javascript变量提升

    记住以下两点会对了解javascript有帮助: 变量提升 javascript引擎在编译js代码的时候会先将变量...

网友评论

      本文标题:深入理解JavaScript之变量提升

      本文链接:https://www.haomeiwen.com/subject/uapeactx.html