javascript---执行上下文(一)

执行上下文  (同名:执行上下文环境),先讲述全局环境下的三种情况;


情况一:


控制台直接输入 console.log(a);  ==>  a is not defind;

控制台输入        console.log(a);  ==>  undefind;

  var a;

控制台输入   console.log(a);  ==>  undefind;

  var a = 10;


 分析:第一句a is not defind;表示没有a变量,第二句输出undefind表示a变量定义但是未赋值,说明代码执行之前浏览器已经做了准备工作(声明了变量a),第三局输出undefind表示a变量定义并未赋值,说明在代码执行之前浏览器的准备工作只是声明变量并不赋值。


情况二:


有js开发经验的开发者应该知道,无论在哪个位置获取this都是有值的,所以在执行上下文环境中会直接给this赋值。


情况三:


关于函数,分别在控制台输出console.log(f1); function f1(){};和console.log(f2); var f2 = function(){}; ,得到的结果分别为f1函数和undefind,所以函数声明会在执行上下文环境中声明并赋值,而函数表达式会在执行上下文环境中声明该变量。


总结:变量、函数表达式-----变量声明,默认赋值为undefind;

   this-----赋值;

   函数声明-----赋值;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值