关于javascript中的变量提升和函数提升

这篇文章主要介绍了详解javascript中的变量提升和函数提升的相关资料,需要的朋友可以参考下

1在js中只有两种作用域

a:全局作用域

b:函数作用域

在ES6之前,js是没有块级作用域。

立即学习“Java免费学习笔记(深入)”;

首先来解释一下什么是没有块级作用域?

关于javascript中的变量提升和函数提升

所以此时 是可以打印输出变量a的值。

2:什么是变量提升?

在我们的js中,代码的执行时分两步走的,1、解析 2、一步一步执行

那么变量提升就是变量声明会被提升到作用域的最顶上去,也就是该变量不管是在作用域的哪个地方声明的,都会提升到作作用域的最顶上去。

关于javascript中的变量提升和函数提升

那么上面这种写法其实等价于下面这种写法:

关于javascript中的变量提升和函数提升

看几个例子:

关于javascript中的变量提升和函数提升

把上面的例子稍作改动:

结果就会大不一样,

关于javascript中的变量提升和函数提升

再看一个例子:

关于javascript中的变量提升和函数提升

3:什么是函数提升?

关于javascript中的变量提升和函数提升

输出的结果是:

关于javascript中的变量提升和函数提升

注意:函数声明式,会将函数的声明和定义一起提升到作用域的最顶上去。

如果是这种写法:函数表达式声明的函数

关于javascript中的变量提升和函数提升

例子:

关于javascript中的变量提升和函数提升

输出的结果是:

关于javascript中的变量提升和函数提升

最后的总结:

1:所有的声明都会提升到作用域的最顶上去。

2:同一个变量只会声明一次,其他的会被忽略掉。

3:函数声明的优先级高于变量申明的优先级,并且函数声明和函数定义的部分一起被提升。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

JavaScript设计模式中构造函数模式的介绍

jQuery阻止事件冒泡实例分析

以上就是关于javascript中的变量提升和函数提升的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2747271.html

(0)
上一篇 2025年3月8日 04:18:51
下一篇 2025年3月8日 04:19:02

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JavaScript中getter和setter的介绍

    这篇文章主要介绍了关于javascript中getter和setter的介绍,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 对象的属性是由属性名name,值key,和其他特性(可读写性 writable,可枚举性enumer…

    2025年3月8日 编程技术
    200
  • JS浏览器事件循环机制

    这篇文章主要介绍了关于js浏览器事件循环机制,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 先来明白些概念性内容。 进程、线程 进程是系统分配的独立资源,是 CPU 资源分配的基本单位,进程是由一个或者多个线程组成的。 线程…

    2025年3月8日
    200
  • 用Node处理文件上传

    这篇文章主要介绍了关于用node处理文件上传,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 前言 在Web开发中,文件上传是一个非常常见、非常重要的功能。本文将介绍如何用Node处理上传的文件。 需求分析 由于现在前后端分离…

    2025年3月8日 编程技术
    200
  • 用Node提供静态文件服务

    这篇文章主要介绍了关于用node提供静态文件服务,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 前言 对于一个web应用,提供静态文件(CSS、JavaScript、图片)服务常常是必须的。本文将介绍如何做一个自己的静态文件…

    2025年3月8日
    200
  • 利用javascript判断浏览器类型

    这篇文章主要介绍了关于利用javascript判断浏览器类型,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 判断浏览类型的相关方法 控制台打印浏览器相关信息 window.navigator.userAgent.toLowe…

    编程技术 2025年3月8日
    200
  • 浏览器与NodeJS的EventLoop异同以及部分机制

    这篇文章主要介绍了关于浏览器与nodejs的eventloop异同以及部分机制,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 浏览器与NodeJS的EventLoop异同,以及部分机制 javascript 是一门单线程的脚…

    2025年3月8日 编程技术
    200
  • JavaScript创建对象的四种方式

    这篇文章主要介绍了关于javascript创建对象的四种方式 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 关键字 Object.create; new Object(); new Fn(); {} 背景 此段可跳过不读……

    编程技术 2025年3月8日
    200
  • NodeList 和 HTMLCollection 和 Array的解析

    这篇文章主要介绍了关于nodelist 和 htmlcollection 和 array的解析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 Array,NodeList, HTMLCollection这三个概念和它们之间的…

    2025年3月8日 编程技术
    200
  • vue的父子组件,父子组件传值和vuex的浅析

    这篇文章主要介绍了关于vue的父子组件,父子组件传值和vuex的浅析,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 一、vue的父子组件之间是如何传值的?  首先呢,需要说说的是,vue既然有双向绑定,那为何会有父子组件之间…

    编程技术 2025年3月8日
    200
  • vue 实现数字滚动增加效果

    这篇文章主要介绍了关于vue 实现数字滚动增加效果 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 项目中需要做数字滚动增加的效果,一开始很懵,研究了一下原理,发现很简单,贴出来分享一下 ^_^ 数字滚动组件: 0 expo…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论