一个挺有意思的Javascript小问题说明


先来看以下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高手解惑



相关阅读:
用COM自动服务扩展SQLServer功能
PHPLog php 程序调试追踪工具
用在JavaScript的RequestHelper
CSS教程:定位属性Position
如何删除多级目录
CSS Sprite操作:用CSS处理圆角
Apache服务器之JSP概述篇
解读乔布斯为何抨击Flash是“垂死技术”?
Linux操作系统中RPM命令参数的使用详解
php实现从ftp服务器上下载文件树到本地电脑的程序
用xmanager软件登陆linux的方法
ASP.NET中基类Page_Load方法后执行原因分析
C#教程:使用lambda表达式记录事件日志
CSS实现简单的图片防盗链代码
快速导航

Copyright © 2016 phpStudy |