余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

详解javascript 变量提升(Hoisting)(JavaScript变量提升)

xiyangw 2022-11-26 16:48 8 浏览 0 评论

简介

“变量提升”意味着变量和函数的声明会在物理层面移动到代码的最前面,但这么说并不准确。

实际上变量和函数声明在代码里的位置是不会动的,而是在编译阶段被放入内存中。

声明变量的方法

var、let、const

不用以上关键字直接赋值的变量会挂载与windows环境下;

let a=9
const a=1
var a=6
c=5

声明函数的方法

javascript中声明函数的方法有两种:函数声明式和函数表达式。

//函数声明
function say(){
 console.log('hello') 
}
 
//函数表达式
var say=function (){
 console.log('hello') 
}

提升的好处

JavaScript 在执行任何代码段之前,将函数声明放入内存中的优点之一是,这允许你可以在在声明该函数之前使用一个函数。

/*** 正确的方式:先声明函数,再调用函数 (最佳实践)*/
function catName(name) {
 console.log("我的猫名叫 " + name);
}
catName("Tigger");
/*以上代码的执行结果是: "我的猫名叫 Tigger"*/
 
 
/*** 不推荐的方式:先调用函数,再声明函数 */
catName("Chloe");
function catName(name) {
 console.log("我的猫名叫 " + name);
}
/*代码执行的结果是: "我的猫名叫 Chloe"*/

提升规则

  • var 声明的变量,提升时只声明,不赋值,默认为undefined;不用关键字直接赋值的变量不存在提升(demo1)
  • 函数提升会连带函数体一起提升,不执行;(deom2)
  • 预解析的顺序是从上到下;(demo4)
  • 函数的优先级高于变量,函数声明提前到当前作用域最顶端;(deom3)
  • 变量重名,提升时不会重复定义;在执行阶段后面赋值的会覆盖上面的赋值;(demo4)
  • 函数重名,提升时后面的会覆盖前面;(demo5)
  • 函数和变量重名,提升函数,不会重复定义,变量不会覆盖函数;在执行阶段后面赋值的会覆盖上面的赋值;(demo8)
  • 用函数表达式声明函数,会按照声明变量规则进行提升;(deom6)
  • 函数执行时,函数内部的变量声明和函数声明也按照以上规则进行提升;(deom7)
  • let、const不存在提升;(demo9、demo10)
/**demo1**/
console.log('a=',a) //a=undefined
console.log('b=',b) // Uncaught ReferenceError: b is not defined
var a=1
b=6
 
 
/**deom2**/
console.log('a=',a) // a=function a() {console.log("func a()")}
function a() {
console.log("func a()")
}
 
/**deom3**/
console.log('a=',a) // a=function a() {console.log("fun a")}
var a=3
var a=4
 
function a(){
console.log("fun a")
}
var a=5
var a=6
console.log("a=",a) // a=6
 
 
 
/**deom4**/
console.log('a=',a) // a=undefined
var a =2
console.log('a=',a) //
var a =3
var a =4
console.log('a=',a) // a=4
console.log('b=',b) //b= undefined
var b='b1'
 
 
/**deom5**/
console.log('a=',a) // a=function a() {console.log("a2")}
function a(){
console.log("a1")
}
function a(){
console.log("a2")
}
console.log('a=',a) // a=function a() {console.log("a2")}
 
 
/**deom6**/
console.log('a=',a) // a=undefined
var a=function(){console.log('a1')}
var a=3
var a=4
var a=5
console.log(a)
var a=function(){console.log('a2')}
console.log('a=',a) // a= ? (){console.log('a2')}
 
 
/**deom7**/
console.log('b=',b)
var a=3
function b(i){
 console.log('a=',a)
 var a=4
 function a(){
 console.log('fun a')
 }
 console.log('a=',a)
}
b()
 
 
/**demo8**/
console.log('a=',a) //a= function a(){ console.log('fun a')}
var a=2
function a(){
 console.log('fun a')
}
console.log('a=',a) // a=2
var a=3
var a=4
var a=5
console.log('a=',a) // a=5
 
 
/**demo9**/
console.log('a=',a) //Uncaught ReferenceError: a is not defined
let a=4
 
 
/****/
<!--demo10-->
console.log('b=',b) // Uncaught ReferenceError: b is not defined
const b=5

最后

以下是总结出来最全前端框架视频,包含: javascript/vue/react/angualrde/express/koa/webpack 等学习资料。

【领取方式】

关注头条 前端全栈架构丶第一时间获取最新前端资讯学习

手机用户可私信关键词 【前端】即可获取全栈工程师路线和学习资料!

相关推荐

我的 JavaScript,比你的 Rust 更快(rust vs javascript)
我的 JavaScript,比你的 Rust 更快(rust vs javascript)

JoshUrbane是一位从业多年的软件架构师,很喜欢在社交媒体分享技术观点。近日,他写了一篇文章,记录了自己凭借经验赢了与新人开发者打赌的故事,而“我的...

2023-03-21 19:27 xiyangw

javascript简介(javascript简介ppt)
javascript简介(javascript简介ppt)

javascript诞生于1995年。当时,它的主要目的是处理以前由服务器端语言(如php)负责的一些输入验证操作。在javascript问世之前,必须把表单...

2023-03-21 19:25 xiyangw

JavaScript介绍(javascript简介)

JavaScript是运行在浏览器端的脚步语言,JavaScript主要解决的是前端与用户交互的问题,包括使用交互与数据交互。JavaScript是浏览器解释执行的,前端脚本语言还有JScript(...

为什么我喜欢JavaScript?(为什么我喜欢闻姨妈血的味道)
为什么我喜欢JavaScript?(为什么我喜欢闻姨妈血的味道)

每个开发人员都有自己喜欢的语言。继续读下去,看看为什么这个开发人员喜欢JavaScript,尽管有些奇怪的部分已经让其他人放弃了它。学习如何使用Crafter...

2023-03-21 19:24 xiyangw

JavaScript是什么,如何立足于编程语言之林?
JavaScript是什么,如何立足于编程语言之林?

一、JavaScript这个名字JavaScript,倘若顾名思义,似乎就是Java语言的某种轻量级的脚本语言。而事实上,JavaScript这门语言的初衷也的...

2023-03-21 19:24 xiyangw

Web前端开发基础:HTML、CSS、JavaScript分别实现什么功能?
Web前端开发基础:HTML、CSS、JavaScript分别实现什么功能?

相信正在学习Web前端知识的小伙伴们都知道,学习Web前端开发基础技术需要掌握:HTML、CSS、JavaScript,那么这三个都是分别实现什么功能的呢?下面...

2023-03-21 19:24 xiyangw

关于前端,你不得不知的 8 种JavaScript 趋势和工具
关于前端,你不得不知的 8 种JavaScript 趋势和工具

前端开发人员和技术人员的数量逐年增加,而整个生态系统渴望实现标准化。新技术和工具的出现已经改变了游戏规则。可以肯定地说,总体趋势将是UI标准化、基于组件的模...

2023-03-21 19:24 xiyangw

前端工程师学习JavaScript很有必要,为何这样说呢?
前端工程师学习JavaScript很有必要,为何这样说呢?

JavaScript(简称“JS”)是一种具有函数优先的轻量级、解释型或即时编译型的编程语言,也是当前Web前端工程师学习的主要内容。有较真的同学好奇前端工程师...

2023-03-21 19:23 xiyangw

在工作中经常使用的 5个JavaScript 技巧(电子表格使用技巧大全)

JavaScript高级进阶课程中ES6内容给我们编程带来了很多便利,以前用大量代码实现的功能现在变得非常简洁,总结了工作中经常使用的5个JavaScript技巧,希望对你也有帮助。(1)、找...

JavaScript是一种什么语言?——JS的概念、特点、使用及执行顺序
JavaScript是一种什么语言?——JS的概念、特点、使用及执行顺序

1.JavaScript概念??JavaScript是一种基于原型的面向对象的语言。??同时,因为JavaScript是脚本语言,而脚本语言又是一种解释性的语言...

2023-03-21 19:23 xiyangw

被全球数10万程序员关注收藏!这些JavaScript项目到底强在哪里?
被全球数10万程序员关注收藏!这些JavaScript项目到底强在哪里?

众所周知,JavaScript是当今互联网世界最流行的编程语言之一,也是程序员,特别是前端工程师的必备技能之一。而随着越来越多的程序员使用JavaScript编...

2023-03-21 19:22 xiyangw

java你会正确使用JS吗?JS的十个超级实用性(js的三种使用方式)
java你会正确使用JS吗?JS的十个超级实用性(js的三种使用方式)

导读:你可能刚上手JavaScript,或者只是曾经偶尔用过。不管怎样,JavaScript改变了很多,有些特性非常值得一用。这篇文章介绍了一些特性,在我...

2023-03-21 19:22 xiyangw

Web前端:JavaScript的未来——发展趋势和预测
Web前端:JavaScript的未来——发展趋势和预测

  前端的动态开发总是鼓励开发者在编码和整体外观上做出主动的改变。因此,对web项目进行有见地的修改的渴望会引导你挖掘更多关于JavaScript的信息。  J...

2023-03-21 19:22 xiyangw

JavaScript的应用(JavaScript的应用场景)
JavaScript的应用(JavaScript的应用场景)

当前互联网用户多达几十亿。传统网站由包含大量链接的网页组成,这种网站正逐渐被包含高度交互元素的单页应用取代,并呈现出加速的趋势。其中的主要原因在于,用户不再像以...

2023-03-21 19:22 xiyangw

了解基本JavaScript,什么是JavaScript?(javascript怎么开启)
了解基本JavaScript,什么是JavaScript?(javascript怎么开启)

JavaScript是一种非常简单的方法来向您的网站添加各种动态元素。除非你有一些编程经验,JavaScript将是一个相当一个新的概念开始-它是相当不同的...

2023-03-21 19:21 xiyangw

取消回复欢迎 发表评论: