一个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中this的使用详解
Nov 08 Javascript
JavaScript基础语法、dom操作树及document对象
Dec 02 Javascript
JavaScript弹窗基础篇
Apr 27 Javascript
详解Node.js模块间共享数据库连接的方法
May 24 Javascript
基于JS实现textarea中获取动态剩余字数的方法
May 25 Javascript
jQuery得到多个值只能用取Class ,不能用取ID的方法
Dec 04 Javascript
使用vue官方提供的模板vue-cli搭建一个helloWorld案例分析
Jan 16 Javascript
webpack公共组件引用路径简化小技巧
Jun 15 Javascript
jquery+css实现Tab栏切换的代码实例
May 14 jQuery
JS事件流与事件处理程序实例分析
Aug 16 Javascript
解决vue初始化项目一直停在downloading template的问题
Nov 09 Javascript
如何在vue中使用kindeditor富文本编辑器
Dec 19 Vue.js
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
《Pokemon Sword·Shield》系列WEB动画《薄明之翼》第2话声优阵容公开!
2020/03/06 日漫
基于php导出到Excel或CSV的详解(附utf8、gbk 编码转换)
2013/06/25 PHP
php封装的smarty类完整实例
2016/10/19 PHP
Laravel登录失败次数限制的实现方法
2020/08/26 PHP
javascript function调用时的参数检测常用办法
2010/02/26 Javascript
jQuery easyui的validatebox校验规则扩展及easyui校验框validatebox用法
2016/01/18 Javascript
jQuery Mobile页面返回不需要重新get
2016/04/26 Javascript
Bootstrap导航中表单简单实现代码
2017/03/06 Javascript
vue.js利用Object.defineProperty实现双向绑定
2017/03/09 Javascript
JS实现浏览上传文件的代码
2017/08/23 Javascript
Node.js 使用递归实现遍历文件夹中所有文件
2017/09/18 Javascript
Vue 按键修饰符处理事件的方法
2018/05/04 Javascript
微信小程序登录态和检验注册过没的app.js写法
2019/05/22 Javascript
nodejs对项目下所有空文件夹创建gitkeep的方法
2019/08/02 NodeJs
vue制作toast组件npm包示例代码
2020/10/29 Javascript
[48:53]2014 DOTA2华西杯精英邀请赛 5 25 LGD VS VG第一场
2014/05/26 DOTA
使用Python设置tmpfs来加速项目的教程
2015/04/17 Python
使用Python写CUDA程序的方法
2017/03/27 Python
python merge、concat合并数据集的实例讲解
2018/04/12 Python
python排序函数sort()与sorted()的区别
2018/09/18 Python
详解多线程Django程序耗尽数据库连接的问题
2018/10/08 Python
对Python定时任务的启动和停止方法详解
2019/02/19 Python
python学习之使用Matplotlib画实时的动态折线图的示例代码
2021/02/25 Python
CSS3 透明色 RGBA使用介绍
2013/08/06 HTML / CSS
美国最受欢迎的度假租赁网站:VRBO
2016/08/02 全球购物
生物化学研究助理员求职信
2013/10/09 职场文书
后勤工作职责
2013/12/22 职场文书
机关财务管理制度
2014/01/17 职场文书
2014年党员公开承诺书范文
2014/03/28 职场文书
民主评议党员总结
2014/10/20 职场文书
2014年老干部工作总结
2014/11/21 职场文书
合同审查法律意见书
2015/06/04 职场文书
教师节随笔
2015/08/15 职场文书
《花钟》教学反思
2016/02/17 职场文书
详解vue中v-for的key唯一性
2021/05/15 Vue.js
叶县这家生产军用电台的兵工厂,人称“四机部”,走出一上将
2022/02/18 无线电