JavaScript 的作用域与变量声明提升
🌙
手机阅读
本文目录结构
问题
JavaScript 的作用域与变量声明提升
参考答案
- 作用域
- 就是作用域里面套作用域;也就是闭包的机制;子集作用域可以访问父级作用域,父级不能访问子级;
- 变量提升
- 作用域里面的带var的这些是该作用域的,如果没有某个变量直接到上一级查找;如果不在var声明,就直接变为上一级作用域的变量;
- javascript中一个名字(name)以四种方式进入作用域(scope),其优先级顺序如下:
- 1、语言内置:所有的作用域中都有
this
和arguments
关键字 - 2、形式参数:函数的参数在函数作用域中都是有效的
- 3、函数声明:形如
function foo() {}
- 4、变量声明:形如
var bar
let aaa
;
- 1、语言内置:所有的作用域中都有
- 名字声明的优先级如上所示;
- 就是说如果一个变量的名字与函数的名字相同,那么函数的名字会覆盖变量的名字,无论其在代码中的顺序如何。
- 但名字的初始化却是按其在代码中书写的顺序进行的,不受以上优先级的影响。
- 命名函数表达式
- 可以像函数声明一样为函数表达式指定一个名字,但这并不会使函数表达式成为函数声明。
- 命名函数表达式的名字不会进入名字空间,也不会被提升。
- 命名函数表达式的名字只在该函数的作用域内部有效。
- javascript中则是这样
- var v;//声明变量v
- v = “hello”;//(定义并)初始化变量v
- 因为javascript为动态语言,其变量并没有固定的类型,其存储空间大小会随初始化与赋值而变化,所以其变量的“定义”就不像传统的静态语言一样了,其定义显得无关紧要。
更多面试题
如果你想了解更多的前端面试题,可以查看本站的WEB前端面试题 ,这里基本包涵了市场上的所有前端方面的面试题,也有一些大公司的面试图,可以让你面试更加顺利。
面试题 | ||
---|---|---|
HTML | CSS | JavaScript |
jQuery | Vue.js | React |
算法 | HTTP | Babel |
BootStrap | Electron | Gulp |
Node.js | 前端经验相关 | 前端综合 |
Webpack | 微信小程序 | - |
这些题库还在更新中,如果你有不错的面试题库欢迎分享给我,我整理后放上来;人人为我,我为人人,互帮互助,共同提高,祝大家都拿到心仪的Offer!