前端基础的讲解-JS(10)

作用域链

通过上节作用域我们知道,当我们声明一个函数时,程序会生成一个独立的作用域,如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域;根据 内部函数可以访问外部函数变量 的这种机制,用链式查找决定哪些数据能被内部函数访问,就称为作用域链

作用域链采取就近原则的方式来查找变量最终的值。

javascript 复制代码
function  item1(){
let  num  =  123;
function  item2(){
console.log(num);  //  123
} 
item2();
}
let  num  =  456; 
item1();

JavaScript 预解析(重点)

JavaScript 代码是由浏览器中的 JavaScript 解析器来执行的。JavaScript 解析器在运行 JavaScript 代码的时候分为两步

  • 预解析
  • 代码执行

变量预解析(变量提升) 变量的声明会被提升到当前作用域的最上面,变量的赋值不提升

函数预解析(函数提升)函数的声明会被提升到当前作用域的最上面,但是不会调用函数

在当前作用域下,JS 代码执行之前,浏览器会默认把带有 var 和 function 声明的变量在内存中进行提前声明或定义,预解析会把变量和函数的声明在代码执行之前完成,预解析也叫做变量、函数提升

相关推荐
xiezhr5 分钟前
在trae的帮助下开发了俄罗斯方块游戏
前端·javascript·html
嘉小华10 分钟前
深入浅出Android ViewBinding
前端
嘉小华14 分钟前
深入浅出Android DataBinding
前端
赫本的猫14 分钟前
JavaScript作用域详解:从基础到欺骗词法
前端·javascript
星河丶15 分钟前
React 虚拟 DOM 的 Diff 算法原理
前端·react.js
赫本的猫15 分钟前
JavaScript 预编译机制深度解析
前端·javascript
伍哥的传说25 分钟前
Vue3 响应式翻牌抽奖游戏
javascript·vue.js·游戏·前端框架·vue·交互
涛々35 分钟前
uniapp-vue3-js-vite-pinia-eslint 快速开发模板
javascript·uni-app·uniapp+vue3模板
Morpheon40 分钟前
R语言非结构化文本挖掘入门指南
开发语言·r语言
解道Jdon1 小时前
最新苹果液体玻璃Liquid Glass效果CSS实现
javascript·reactjs