最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • JS变量提升和函数提升

    正文概述 掘金(potS.)   2021-04-22   496

    1.变量提升

    在ES6之前,我们声明一个变量需要用到var关键字,用var来声明的变量就存在变量提升的特性。

    JS变量提升和函数提升

    上述代码粗略来讲解,在上述代码中存在全局作用域和函数作用域,在两个作用域中都声明了变量a。在fn函数执行console.log(a)的时候,先会在自身所处在的函数作用域中找到变量a,

    如果没有找到,就会去全局作用域中找。

    在fn函数作用域中我们可以看到a变量声明并赋值了,但是它处于console.log(a)语句的下方,按照正常的逻辑,它不应该找到的是外层定义的a吗?但是结果恰恰相反。

    代码执行流程:

    我们可以根据位置来把代码分为全局代码和函数(局部)代码。在执行全局代码前,首先将window添加为全局执行上下文,之后对全局数据做预处理工作:

    (1)找到var关键声明的变量,赋值为undefined,且添加为window的属性。=>变量提升

    (2)将function声明的变量赋值fun(),添加为window属性。=>函数提升

    (3)this =>赋值window

    在预处理结束后,开始执行全局代码。

    函数代码执行流程也和上述大同小异,这里涉及到执行上下文,就不细讲了,后续会补充。

    所以我们可以这样理解这行代码

    JS变量提升和函数提升

    最后的结果自然就是undefined。这就是js存在的变量提升。

    2.函数提升

    函数提升和变量提升的原理一样,区别就是在于,函数提升已经创建好了函数对象,而变量提升赋值为undefined,可以理解为变量声明提升。

    JS变量提升和函数提升

    JS变量提升和函数提升

    3.拓展

    (1)var fn = function(){}和function fn(){}的区别:前者为变量提升,后者为函数提升。

    JS变量提升和函数提升

    JS变量提升和函数提升

    如果是用变量提升来声明函数,如果在此前调用该函数,此时的函数对象并没有创建,变量fn2赋值为undefined,所以浏览器不能识别,把它当做函数来调用,所以最后报错。

    (2)在js中,函数是第一公民

    被覆盖的不是函数fn,而是var fn =3;

    JS变量提升和函数提升

    结果:

    JS变量提升和函数提升


    起源地下载网 » JS变量提升和函数提升

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元