一个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 相关文章推荐
ie focus bug 解决方法
Sep 03 Javascript
javascript异步编程的4种方法
Feb 19 Javascript
jQuery如何取id有.的值一般的方法是取不到的
Apr 18 Javascript
javascript中Number对象的toString()方法分析
Dec 20 Javascript
jQuery实现根据类型自动显示和隐藏表单
Mar 18 Javascript
jQuery中JSONP的两种实现方式详解
Sep 26 Javascript
etmvc+jQuery EasyUI+combobox多值操作实现角色授权实例
Nov 09 Javascript
JS简单获取当前年月日星期的方法示例
Feb 07 Javascript
利用node.js写一个爬取知乎妹纸图的小爬虫
May 03 Javascript
jQuery Form插件使用详解_动力节点Java学院整理
Jul 17 jQuery
vue基于mint-ui的城市选择3级联动的示例
Oct 25 Javascript
vue实现图片预览组件封装与使用
Jul 13 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
PHP的FTP学习(三)
2006/10/09 PHP
PHP 数组排序方法总结 推荐收藏
2010/06/30 PHP
php实现倒计时效果
2015/12/19 PHP
Yii2中YiiBase自动加载类、引用文件方法分析(autoload)
2016/07/25 PHP
北京奥运官方网站幻灯切换效果flash版打包下载
2008/01/30 Javascript
JS实现鼠标单击与双击事件共存
2014/03/08 Javascript
node.js中的socket.io入门实例
2014/04/26 Javascript
javascript实现获取字符串hash值
2015/05/10 Javascript
用node和express连接mysql实现登录注册的实现代码
2017/07/05 Javascript
JS实现按钮颜色切换效果
2020/09/05 Javascript
axios post提交formdata的实例
2018/03/16 Javascript
用Vue写一个分页器的示例代码
2018/04/22 Javascript
Nodejs在局域网配置https访问的实现方法
2020/10/17 NodeJs
原生js实现弹幕效果
2020/11/29 Javascript
[01:59][TI9趣味视频] 全明星赛奖励
2019/08/23 DOTA
python获取豆瓣电影简介代码分享
2014/01/16 Python
Python while、for、生成器、列表推导等语句的执行效率测试
2015/06/03 Python
Python for Informatics 第11章之正则表达式(四)
2016/04/21 Python
python递归函数绘制分形树的方法
2018/06/22 Python
python 去除二维数组/二维列表中的重复行方法
2019/01/23 Python
浅谈Python3中strip()、lstrip()、rstrip()用法详解
2019/04/29 Python
基于python全局设置id 自动化测试元素定位过程解析
2019/09/04 Python
matplotlib自定义鼠标光标坐标格式的实现
2021/01/08 Python
美国时尚女装在线:Missguided
2016/12/03 全球购物
美国第一香水网站:Perfume.com
2017/01/23 全球购物
香港永安旅游网:Wing On Travel
2017/04/10 全球购物
SQL面试题
2013/04/30 面试题
文秘专业应届生求职信范文
2013/11/14 职场文书
采购部经理岗位职责
2014/02/10 职场文书
洗车工岗位职责
2014/03/15 职场文书
《开国大典》教学反思
2014/04/19 职场文书
大学生村官个人对照检查材料(群众路线)
2014/09/26 职场文书
幼儿园教师节感谢信
2015/01/23 职场文书
2015年医院创卫工作总结
2015/04/22 职场文书
在校证明模板
2015/06/17 职场文书
Python中requests做接口测试的方法
2021/05/30 Python