JavaScript变量声明提前

简介:

上周四 吃完午饭,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 = 'hello world'; 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 = 'hello world'; var b;

 

第二题解析:b='hello world',程序首先会在函数内部去查找是否有变量b的声明,如果有的话,直接赋值为'hello world'。但是alert( typeof b); 是在函数外面,输出的全局变量b,所有是undefined。

 
 

接着看如下代码段:

 

<script type="text/javascript">
    name = "aaa";

    function test() {
        alert(typeof name);
        var name = "bbb";
        alert(typeof name);
    }
    test();
</script>

请写出结果。

分析可以写成如下代码段:

myname = "aaa";

function test() {
        alert(typeof myname); //在函数内部查找是否有myname的声明,有声明,但未赋值。所以typeof myname为undefined
  var myname=123;//赋值操作 
  alert(typeof myname);//number
} 
test();

 

但是下面代码段,运行结果是什么?

<script type="text/javascript">
    alert(typeof name);
    var name = "hello world";
    alert(typeof name);
</script>

程序运行结果是:string,string。原因是什么?

 

注意:通 过和园友的共同讨论,有了结果了。关于最后出现string和string的结果,确实是因为Chrome浏览器默认给name赋值了name="",所 以输出的结果为string。这里给大家提醒了一下,在前端开发过程中,我们很多时候都在关注CSS和HTML的在各个浏览器中的兼容器,但是有时 JavaScript在各个浏览器中也有兼容性问题。

目录
相关文章
|
13天前
|
JavaScript
变量和函数提升(js的问题)
变量和函数提升(js的问题)
|
15天前
|
JavaScript 前端开发
JavaScript 中如何检测一个变量是一个 String 类型?
JavaScript 中如何检测一个变量是一个 String 类型?
21 2
|
3月前
|
JavaScript 前端开发 Java
JavaScript基础语法(变量)
JavaScript基础语法(变量)
48 0
|
4月前
|
JavaScript 前端开发
JavaScript变量、数据类型、运算符及类型转换
JavaScript变量、数据类型、运算符及类型转换
40 0
|
1月前
|
JavaScript 前端开发 容器
javascript中的变量定义
javascript中的变量定义
|
1月前
|
存储 JavaScript 前端开发
编程笔记 html5&css&js 075 Javascript 常量和变量
编程笔记 html5&css&js 075 Javascript 常量和变量
|
2月前
|
XML 存储 JavaScript
深入理解JS语法与变量
深入理解JS语法与变量
44 1
|
3月前
|
JavaScript 前端开发 C++
给初学者的JavaScript入门指南及通俗的JS变量解释
给初学者的JavaScript入门指南及通俗的JS变量解释
129 0
|
3月前
|
自然语言处理 JavaScript 前端开发
JavaScript:作用域&变量回收
JavaScript:作用域&变量回收
31 1
|
3月前
|
存储 JavaScript 前端开发
【JavaScript保姆级教程】输出函数和初识变量
【JavaScript保姆级教程】输出函数和初识变量