• 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在各个浏览器中也有兼容性问题。

    转载自:liminjun88(包含链接http://www.cnblogs.com/liminjun88/)

  • 相关阅读:
    CSS------添加注释框
    MyEclipse------制作通讯录
    JavaScript------入门
    JSTL标签库简介
    过滤器在Web开发应用------解决中文乱码
    Servlet------(声明式)异常处理
    电脑环境变量里面的参数
    MyEclipse------黑科技
    MyEclipse------从MySQL取出图片
    MyEclipse------带进度条的输入流
  • 原文地址:https://www.cnblogs.com/michael-xiang/p/4551202.html
Copyright © 2020-2023  润新知