JavaScript中的变量提升和函数提升

在EcmaScript5中只有全局作用域和函数作用域,EcmaScript6增加了块级作用域。
块级作用域(一对花括号{}即为一个块级作用域)

变量提升

console.log(name);  //undefined
var name = "Hello JoeXin!";
console.log(name);  //Hello JoeXin!
    function f() {
        console.log(name); //undefined
        var name = "JoeXin";
        console.log(name); //JoeXin
    }
f();       

实质

var name; // 变量提升,全局作用域范围内,此时只是声明,并没有赋值
console.log(name); // undefined
name = 'Hello JoeXin!'; // 此时才赋值
console.log(name); // 打印出Hello JoeXin!
 
function fn () {
  var name; // 变量提升,函数作用域范围内
  console.log(name);
   name = 'JoeXin';
  console.log(a);
}
fn();

函数提升

js中创建函数有两种方式:函数表达式和函数声明方式。只函数声明方式才存在函数提升!

函数声明方式提升


function myTest(){
    foo();
    function foo(){
        alert("我来自 foo");
    }
}
myTest();

函数表达式方式提升 失败

function myTest(){
   foo();
   var foo =function foo(){
        alert("我来自 foo");
   }
}
myTest();  //  打印出  foo is not a function

转载于:https://www.cnblogs.com/joexin/p/7215276.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值