一个挺有意思的Javascript小问题说明_javascript技巧
程序员文章站
2022-05-01 17:00:43
...
先来看以下3段代码
var firstName = "Mark";
(function DisplayFirstName() {
console.log(firstName);
})();//必然输出 Mark
var lastName = "Aut";
(function DisplayLastName() {
var lastName = "Bru";
console.log(lastName);
})();//必然输出 Bru, 本地作用域的优先级高于全局作用域
//那么下面这段代码呢?
var lastName = "Aut";
(function DisplayLastName() {
console.log(lastName);
var lastName = "Bru";
console.log(lastName);
})();//谁能猜出结果是什么?
这个输出的结果是:
LOG: undefined
LOG: Bru
这出乎了我的意料, 我原来以为应该是 "Aut" 和 "Bru"的
我原来的理解是: 在程序第一个输出lastName的时候, 程序没有找到本地声明的lastName变量,所以使用了全局的lastName定义, 第二次的时候才使用本地变量的值
(因为在我的概念里,javascript是解释型语言,一句一句的......执行)
看到这个结果,看来javascript的执行并不都是顺序的..
目前为止,就我的猜测,javascript执行应该是先做语法分析,然后顺便分析完成了变量表(本地和全局)
然后才开始顺序执行一行行脚本
还请各位javascript高手解惑
复制代码 代码如下:
var firstName = "Mark";
(function DisplayFirstName() {
console.log(firstName);
})();//必然输出 Mark
var lastName = "Aut";
(function DisplayLastName() {
var lastName = "Bru";
console.log(lastName);
})();//必然输出 Bru, 本地作用域的优先级高于全局作用域
//那么下面这段代码呢?
var lastName = "Aut";
(function DisplayLastName() {
console.log(lastName);
var lastName = "Bru";
console.log(lastName);
})();//谁能猜出结果是什么?
这个输出的结果是:
LOG: undefined
LOG: Bru
这出乎了我的意料, 我原来以为应该是 "Aut" 和 "Bru"的
我原来的理解是: 在程序第一个输出lastName的时候, 程序没有找到本地声明的lastName变量,所以使用了全局的lastName定义, 第二次的时候才使用本地变量的值
(因为在我的概念里,javascript是解释型语言,一句一句的......执行)
看到这个结果,看来javascript的执行并不都是顺序的..
目前为止,就我的猜测,javascript执行应该是先做语法分析,然后顺便分析完成了变量表(本地和全局)
然后才开始顺序执行一行行脚本
还请各位javascript高手解惑
上一篇: 使用Blod做出ajax的进度条下载
推荐阅读
-
在多个页面使用同一个HTML片段的代码_javascript技巧
-
一个简单的Node.js异步操作管理器分享_javascript技巧
-
JS实现求出一个字符串中最多出现的字符和个数_javascript技巧
-
一个原生的用户等级的进度条_javascript技巧
-
来自腾讯的一个不固定高度得消息的滚动特效_javascript技巧
-
javascript加号"+"的二义性说明_javascript技巧
-
推荐一个封装好的getElementsByClassName方法_javascript技巧
-
一个简单的Node.js异步操作管理器分享_javascript技巧
-
IE本地存储userdata的一个bug说明_javascript技巧
-
Javascript-Mozilla和IE中的一个函数直接量的问题分析_javascript技巧