您现在的位置是:首页 > Javascript
当前栏目
[javascript] 变量提升
2023-02-18 15:41:46 时间
摘自廖雪峰网站
JavaScript的函数定义有个特点,它会先扫描整个函数体的语句,把所有申明的变量“提升”到函数顶部:
'use strict'; function foo() { var x = 'Hello, ' + y; console.log(x); var y = 'Bob'; } foo();
虽然是strict模式,但语句var x = 'Hello, ' + y;并不报错,原因是变量y在稍后申明了。但是console.log显示Hello, undefined,说明变量y的值为undefined。这正是因为JavaScript引擎自动提升了变量y的声明,但不会提升变量y的赋值。
对于上述foo()函数,JavaScript引擎看到的代码相当于:
function foo() { var y; // 提升变量y的申明,此时y为undefined var x = 'Hello, ' + y; console.log(x); y = 'Bob'; }
由于JavaScript的这一怪异的“特性”,我们在函数内部定义变量时,请严格遵守“在函数内部首先申明所有变量”这一规则。最常见的做法是用一个var申明函数内部用到的所有变量:
function foo() { var x = 1, // x初始化为1 y = x + 1, // y初始化为2 z, i; // z和i为undefined // 其他语句: for (i=0; i<100; i++) { ... } }
相关文章
- JS算法之动态规划
- JS_基础知识点精讲
- JS_手写实现
- JS算法_知识点精讲
- .NET7 gRPC JSON转码+OpenAPI
- 一门看懂Node处理CPU密集型任务的方法有哪些
- 使用Node构建一个高效的静态文件服务器
- 一文带你看懂Node的Buffer类
- JavaScript刷LeetCode拿offer-高频40题
- 用javascript分类刷leetcode--位运算(图文视频讲解)
- JavaScript刷LeetCode拿offer之失败-滑动窗口
- 用javascript分类刷leetcode---动态规划(图文视频讲解)
- 手写JavaScript常见5种设计模式1
- FastJson反序列化漏洞修复
- JDK中内嵌JS引擎介绍及使用
- 49195,npm最后的疯狂?盘点10款最有前途JavaScript构建工具
- 译文:5个增强Node.js应用程序增强功能
- 4个例子,吃透 JavaScript 实现的二叉搜索树 BST
- Vue中使用XML和JSON格式互转插件
- JDK中Jshell简单使用(JDK9版本以上或者JDK9版本)