温故而知新——检测类型、执行环境


  • instanceof 和 typeof

五种基本数据类型:number string undefined null boolean
基本数据类型用typeof检测比较方便,引用类型用instanceof检测
//五中基本数据类型:undefined null boolean number String
    var a=undefined;
    var b=null;
    var c=true;
    var d=1;
    var e="abc";
    console.log(typeof a);//undefined
    console.log(typeof b);//object 
    console.log(typeof c);//boolean
    console.log(typeof d);//number
    console.log(typeof e);//string
    console.log(a instanceof Object);//false
    console.log(b instanceof Object);//false
    function testFormalStyle(){}
    var f=new testFormalStyle();
    console.log(typeof f);//object
    console.log(f instanceof testFormalStyle);//true
    var g=/\d/g;
    console.log(typeof g);//object
    console.log(g instanceof RegExp);//true


  • 执行环境及作用域

  1. 执行环境定义了变量或函数有权访问的其他数据,决定了他们各自的行为,每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量和函数都保存在这个对象中。
  2. 在web浏览器中,全局执行环境被认为是window对象,因此所有全局变量和函数都是作为window对象的属性和方法创建的。某个执行环境中的所有代码执行完毕后,该环境被销毁,保存在其中的所有变量和函数定义也随之销毁。
  3. 每个函数都有自己的执行环境。当执行流进入一个函数时,函数的环境就会被推入一个环境栈中。而在函数执行之后,栈将其环境弹出,把控制权返回给之前的执行环境。
  4. 当代码在一个环境中执行时,会创建变量对象的一个作用域链(作用域链用途:保证对执行环境有权访问的所有变量和函数的有序访问。)作用域链的前端,始终都是当前代码所在环境的变量对象。如果这个环境是函数,则将其活动对象作为变量对象。作用域链中的下一个变量对象来自与包含(外部)环境,而再下一个变量对象则来自下一个包含环境。这样一直延续到全局变量环境。

//eg:
function test(){
    var i=1;
    return function(){
        console.log(i++);
    }
}
var f1=test();
f1();//1
f1();//2
var f2=test();
f2();//1

函数执行过程==执行环境==在栈中的存储过程:
这里写图片描述

那么问题来了:如果f1()执行时test()的执行环境已经出栈了,那么f1()执行时还能获取的到i的值么,答案是肯定的:能获取到。这就涉及到我们的另外一个概念:==数据链==。

那么在f1()执行时,在改函数执行环境里存在的数据链是这样的:
这里写图片描述

虽然test()执行环境从已经出栈,但是匿名函数中用到的i变量还是能从数据链中找到。

ps:js中的执行顺序是:顺序执行的。

 console.log(a);//undefined
 var a=20;
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值