技术咨询、项目合作、广告投放、简历咨询、技术文档下载 点击这里 联系博主

# Javascript的变量提升和函数提升

# Javascript的变量提升和函数提升

在JavaScript执行代码的过程中是一段一段从上往下执行代码。执行代码之前是有一个预处理过程的,比如变量的提升和函数提升。

# 一、变量提升

通常我们会遇到如下的代码:

console.log(a); //输出结果:undefined
var a="mr gao";
console.log(a);//输出结果:mr gao

function demo(){
  console.log(a);//输出结果:undefined
  var a="demo";
  console.log(a);//输出结果:demo

}
demo();

其实javascript在预处理过程时,会将声明的变量提升至对应作用域的顶端;所以上述的代码类似于:

var a; //变量提升,如果当前作用域有相同的变量名,则会被提升至同一位置。
console.log(a); //输出结果:undefined
a="mr gao";
console.log(a);//输出结果:mr gao

function demo(){
  var a;
  console.log(a);//输出结果:undefined
  a="demo";
  console.log(a);//输出结果:demo

}
demo();

# 二、函数提升

在搞懂函数提升之前先要了解函数声明的几种方式:

//1:函数声明方式
function funName(){

}

//2:函数表达式
}
var funName=function(){

}
//3:函数对象方式

var funcName=new Function();

只有函数声明方式采用函数作用域的提升

foo(); // 不是ReferenceError, 而是TypeError!
var foo = function bar() {
// ...
};

这段程序中的变量标识符foo() 被提升并分配给所在作用域(在这里是全局作用域),因此 foo() 不会导致ReferenceError。但是foo 此时并没有赋值(如果它是一个函数声明而不 是函数表达式,那么就会赋值)。foo() 由于对undefined 值进行函数调用而导致非法操作, 因此抛出TypeError 异常。

同时也要记住,即使是具名的函数表达式,名称标识符在赋值之前也无法在所在作用域中

foo(); // TypeError
bar(); // ReferenceError
var foo = function bar() {
// ...
};

例子:

# (1)变量提升


demo();//结果为:undefined
var age=20;//这个变量的声明会提升到变量使用之前
function demo() {
    console.log(age);//undefined
    var age=30;
}
//代码解析过程为
var age;
function demo() {
    var age;
    console.log(age);
    age=30;
}
demo();
age=20;

# (2)相同函数名变量提升

function demo(){
  console.log("我是第一个函数啊")
}
demo();
function demo(){
  console.log("我是第二个函数啊")
}
demo();

//执行结果为:我是第二个函数啊   我是第二个函数啊
//执行过程为:
function demo(){//第一个demo函数提升至作用域顶端,第二个同名demo函数也提升至顶端,覆盖第一个demo函数
console.log("我是第二个函数啊")
}
demo()//调用第一个demo函数
demo()//调用第二个demo函数

# (3)函数名和变量名冲突:函数名优先级高(函数优先)


console.log(demo);

var demo="我是变量";
function demo (){
  console.log("我是函数");
}
//输出结果为:
ƒ demo(){
  console.log("我是函数");
}

# 参考

【未经作者允许禁止转载】 Last Updated: 1/16/2025, 12:47:53 PM