zoukankan      html  css  js  c++  java
  • 作用域

    js中变量分为两种,一种是全局变量,一种是局部变量

    浏览器的js解析器对于script内部的内容分为两步

    1、预解析:找一些东西,如变量var、函数function、参数,所有的变量在执行代码之前都是undefined,所有的函数在执行代码之前都是函数块
    遇到重名的则只留下一个,变量和函数重名了,则只留下函数
    2、逐行解读代码
        表达式 可以修改预解析的值
        函数调用
            预解析
            逐行解读代码

    看个例子 demo1

    alert(a);     // function a(){alert(4)}
    var a =1;   
    alert(a);   //  1
    function a() {
        alert(2);
    };
    alert(a);     //  1
    var a = 3;
    alert(a);     //  3
    function a() {
         alert(4);
    };
    alert(a);     //  3
    a() // 报错

     demo2

    script 全局变量 全局函数
    <script> alert(a); // 报错 </script> <script> var a = 1; </script>

    // 由上至下依次执行

    demo3

    <script>
        var a = 1;
        function fn1() {
            alert(a);   // undefined;
            var a =2;
        }
        fn1();
      alert(a); // 1
    </script> <script> var a = 1; function fn1() { alert(a); // 1; 预解析没有找到,会执行逐行解读代码,会顺着作用域链 由里到外 往父级作用域找 a =2; // 修改了父级作用域的值 } fn1();
    alert(a); // 2
    </script>

    <script>
        var a = 1;
        function fn1(a) {
            alert(a);   // 参数a 类似于 (var a;) 所以 为undefined
            a =2;       // 修改了本级作用域的值,只能修改内部的值
        }
        fn1();    // 注意此处没有传递参数
    alert(a); // 1 </script>
  • 相关阅读:
    Hibernate 中出现 XXXX is not mapped 问题
    记录一下表格用poi的导出word
    [转帖] 悟透JavaScript
    JAVA读取Oracle中的blob图片字段并显示
    vs2010代码段,用得飞起~
    FontFamily获取中文名字
    vs2010快捷键
    WPF Binding基础
    Binding对数据的转换和校验
    WPF个UI元素
  • 原文地址:https://www.cnblogs.com/fire-passiontao/p/5964548.html
Copyright © 2011-2022 走看看