ES5变量提升

//=>变量提升:var x; var y;
// 此时不仅仅定义了fn,同时给fn一个空间地址,把fn对应的代码字符串放到对应的空间内;
console.log(x, y);//undefined undefined 
var x = 10,
    y = 20;//=>x=10  y=20
console.log(x,y);//10 20 

//=>函数创建的时候就是字符串
function fn() {
    //=>[私有作用域]
    //=>变量提升和this:var x; (x是私有变量)
    console.log(x, y);//=>undefined 20
    var x = y = 100;//=>x=100(私有)  y=100(全局)
    console.log(x, y);//=>100 100
}
fn();//=>执行的时候,此时函数变为真正的js代码
console.log(x, y);//=>10,100;因为这个y对应的值在fn中改变了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值