一个JavaScript变量声明的知识点


Posted in Javascript onOctober 28, 2013

上周四吃完午饭,leader发了一道JavaScript的题目给我们做,我们Team里面有做前端的,有做后台的,也有坐mobile web的,所以大家对题目的理解各自都不一样,然后在QQ讨论组里面进行讨论。发现虽然很基础,但是通过讨论收获不少,分享出来。当然在有开发经验的开发者看来,这些都是学习JavaScript最基础的东西。因为平时都是用jQuery或者第三JS组件,所以对JavaScript基础学习不够重视。题目如下,问题是:2次alert分别输出什么结果?

<script
type="text/javascript">
    var a = 1;
    var a;
    alert(typeof a);
    (function () {
        b = '-----';
        var b;        
    })();
    alert( typeof b);
</script>

我的答案是:1.undefined 2.undefined。然后leader让我们再仔细考虑一下问题答案。我对题目的分析:
1.声明a并赋值为1,然后用重新声明a,但是此时没有赋值,那变量默认值应该为undefined。
2.b变量是在函数里面是局部变量,alert里面输出的是全局变量b,所以为undefiend。
我自己在Chrome里面运行了一下代码,代码正确结果是1.number 2.undefined。这里考察的是JavaScript的变量声明提前概念。
我们在看另外一个例子,比如下面:
test();
function test(){
    alert("Hello World!");
}

程序不会报错,而已运行结果是:Hello World!。原理:计算机在开始执行语句之前,会先查找所有的function定义,然后保存相关的function。
第1题:
var a = 1;
var a;
第2行声明变量a,就相当于在顶部声明了a,然后第一句是重新声明a,然后赋值为1。所以typeof a为number
第2题:
b = '-----';
var b;
第二题解析:b=‘-----',程序首先会去查找上下文是否有变量b的声明,如果有的话,直接赋值为'-----'。但是alert( typeof b); 是在函数外面,输出的全局变量b,所有是undefined。
请注意:对变量的赋值操作并没有提前。
接着看如下代码段:
<script type="text/javascript">
name="aaa";
function test(){
    alert(typeof name);    var name="bbb";
    alert(typeof name);
}
test();
</script>

请写出结果。
分析可以写成如下代码段:
name="aaa";
function test(){
    alert(typeof name);//在函数内部查找上下文是否有name的声明,有声明。但是赋值操作不能提前,所以类型为undefined
    var name="bbb";//赋值操作
    alert(typeof name);//string
}
test();

但是下面代码段,运行结果是什么?
<script type="text/javascript">
alert(typeof name);
var name="hello world";
alert(typeof name);
</script>

程序运行结果是:string,string。这里就弄晕了,不知道怎么分析和解释了。表明上我觉得我理解了变量声明提前,但是用学到方法分析上面代码段,我会得出错误的结果。那么变量的赋值和在函数外部(全局变量)还是函数内部(局部变量)有关系?
Javascript 相关文章推荐
Javascript操作select方法大全[新增、修改、删除、选中、清空、判断存在等]
Sep 26 Javascript
15 个 JavaScript Web UI 库
May 19 Javascript
javascript与css3动画结合使用小结
Mar 11 Javascript
JS使用ajax从xml文件动态获取数据显示的方法
Mar 24 Javascript
javascript带回调函数的异步脚本载入方法实例分析
Jul 02 Javascript
JavaScript中解析JSON数据的三种方法
Jul 03 Javascript
jquery实现简单文字提示效果
Dec 02 Javascript
小程序开发实战:实现九宫格界面的导航的代码实现
Jan 19 Javascript
Javascript中click与blur事件的顺序详析
Apr 25 Javascript
JavaScript实现的超简单计算器功能示例
Dec 23 Javascript
Vue使用json-server进行后端数据模拟功能
Apr 17 Javascript
JavaScript 继承 封装 多态实现及原理详解
Jul 29 Javascript
Javascript实现页面跳转的几种方式分享
Oct 26 #Javascript
javascript中简单的进制转换代码实例
Oct 26 #Javascript
javascript通过navigator.userAgent识别各种浏览器
Oct 25 #Javascript
javascript上传图片前预览图片兼容大多数浏览器
Oct 25 #Javascript
图片动画横条广告带上下滚动的JS代码
Oct 25 #Javascript
使用 Node.js 做 Function Test实现方法
Oct 25 #Javascript
详细介绍8款超实用JavaScript框架
Oct 25 #Javascript
You might like
声音就能俘获人心,蕾姆,是哪个漂亮小姐姐配音呢?
2020/03/03 日漫
ThinkPHP与PHPExcel冲突解决方法
2011/08/08 PHP
php解析非标准json、非规范json的方式实例
2020/12/10 PHP
jQuery使用手册之三 CSS操作
2007/03/24 Javascript
IOS中safari下的select下拉菜单文字过长不换行的解决方法
2016/09/26 Javascript
JavaScript通过filereader接口读取文件
2017/05/10 Javascript
VUE基于NUXT的SSR 服务端渲染
2018/11/30 Javascript
性能优化篇之Webpack构建速度优化的建议
2019/04/03 Javascript
vuex 中插件的编写案例解析
2019/06/10 Javascript
Vue打包部署到Nginx时,css样式不生效的解决方式
2020/08/03 Javascript
vue-cli3中配置alias和打包加hash值操作
2020/09/04 Javascript
js面向对象封装级联下拉菜单列表的实现步骤
2021/02/08 Javascript
[48:00]完美世界DOTA2联赛循环赛 Forest vs Inki BO2第二场 11.04
2020/11/04 DOTA
在Python的Flask框架中构建Web表单的教程
2016/06/04 Python
Python生成8位随机字符串的方法分析
2017/12/05 Python
使用Python爬取最好大学网大学排名
2018/02/24 Python
Python读取英文文件并记录每个单词出现次数后降序输出示例
2018/06/28 Python
浅谈python的深浅拷贝以及fromkeys的用法
2019/03/08 Python
Python跳出多重循环的方法示例
2019/07/03 Python
使用 Supervisor 监控 Python3 进程方式
2019/12/05 Python
Python模块_PyLibTiff读取tif文件的实例
2020/01/13 Python
python用opencv完成图像分割并进行目标物的提取
2020/05/25 Python
Vrbo西班牙:预订您的度假公寓(公寓、乡村房屋…)
2020/04/27 全球购物
全球异乡人的跨境社交电商平台:Kouhigh口嗨网
2020/07/24 全球购物
软件测试英文面试题
2012/10/14 面试题
高中数学教师求职信
2013/10/30 职场文书
超市采购员岗位职责
2014/02/01 职场文书
物流专员岗位职责
2014/02/17 职场文书
竞选班干部演讲稿
2014/04/24 职场文书
学校安全防火方案
2014/06/07 职场文书
领导干部个人对照检查材料(群众路线)
2014/09/26 职场文书
执法作风整顿剖析材料
2014/10/11 职场文书
防汛通知
2015/04/25 职场文书
休假证明书
2015/06/24 职场文书
2015年暑期社会实践总结
2015/07/13 职场文书
2016元旦文艺汇演主持词(开场白+结束语)
2015/12/03 职场文书