JavaScript 中的变量和函数提升
来源:互联网 发布:淘宝买家钻号 编辑:程序博客网 时间:2024/06/11 21:52
直入主题,JavaScript 中的变量和函数提升,有时还是容易错的,记录一下。
// ReferenceError: noSuchVariable is not definedconsole.log(noSuchVariable);
// Outputs: undefinedconsole.log(declaredLater);var declaredLater = "Now it's defined!";// Outputs: "Now it's defined!"console.log(declaredLater);
JavaScript 解释器“前瞻性”查找所有变量定义,把它们“提升”到函数顶部。等价于:
var declaredLater;// Outputs: undefinedconsole.log(declaredLater);declaredLater = "Now it's defined!";// Outputs: "Now it's defined!"console.log(declaredLater);
var nickname = "Baggins";(function () { // Outputs: "Original nickname was undefined" console.log("Original nickname was " + nickname); var nickname = "Underhill"; // Outputs: "New nickname is Underhill" console.log("New nickname is " + nickname);})();
内部作用域定义了 nickname , nickname 变量提升,为 undefined。
等价于
var nickname = "Baggins";(function () { var nickname; // Outputs: "Original nickname was undefined" console.log("Original nickname was " + nickname); nickname = "Underhill"; // Outputs: "New nickname is Underhill" console.log("New nickname is " + nickname);})();
由于此原因一些 JavaScript 风格指南,建议把所有变量定义放到函数的头部。
函数定义不仅提升了函数名,也提升了真正的函数定义。
// Outputs: "Yes!"isItHoisted();function isItHoisted() { console.log("Yes!");}
函数定义提升仅仅作用于函数定义,而不是函数表达式(只有申明会提升,赋值却不会提升)。例如:
// Outputs: "Definition hoisted!"definitionHoisted();// TypeError: undefined is not a functiondefinitionNotHoisted();function definitionHoisted() { console.log("Definition hoisted!");}var definitionNotHoisted = function () { console.log("Definition not hoisted!");};
我们看到了两种不同类型的提升,变量 definitionNotHoisted 定义提升(因此结果是 undefined ),但是函数定义(等号右边的部分)未提升(因此 TypeError)。
你可能想知道使用命名函数表达式会怎样:
// ReferenceError: funcnickname is not definedfuncnickname();// TypeError: undefined is not a functionvarnickname();var varnickname = function funcnickname() { console.log("Definition not hoisted!");};
如你所见,如果函数的名字是函数表达式的一部分,它不会得到提升。
参考资料:
Variable and Function Hoisting in JavaScript
转载自 http://jinlong.github.io/2013/09/11/var-and-fun-hoisting/
0 0
- javascript中的变量提升和函数提升
- JavaScript 中的变量和函数提升
- 【转】JavaScript 中的变量和函数提升
- javascript中的变量提升和函数提升详解
- javascript中的变量提升和函数声明提升
- JavaScript变量提升和函数提升
- JavaScript:变量提升和函数提升
- javascript变量提升和函数提升
- js中的变量提升和函数提升
- javascritp中的变量提升和函数提升
- javascript 变量/函数 提升
- JavaScript 中的变量提升
- JS中的函数声明提升和变量声明提升
- 变量提升和函数提升
- 函数和变量提升
- 变量和函数提升
- JavaScript—变量提升、函数提升
- 浅谈JavaScript变量提升与函数提升
- Nginx+Lua+WeedFS安装手记
- volatile 变量
- ubuntu下允许root用户ssh远程登录及Linux下服务的启动
- 密码切换显示和隐藏 并且保证切换时候EditText显示在最后一行
- android采用Chrome Intent方式实现从浏览器启动应用
- JavaScript 中的变量和函数提升
- 《疯狂Java讲义(第3版)》.(李刚)——面向对象(上)
- 【转载】python获取文件及文件夹大小
- 在android中用NetworkImageView读取网络图片并通过ListView显示出来
- 剑指offer|从尾到头打印链表
- IOS NetworkExtension 框架使用笔记
- Android入门--Intent数据传递
- 影响蓝牙BLE设备功耗的几个因素
- 【刷题之路】有序数组组合问题