javascript作用域链以及函数的预加载功能变量的执行规则

// ------------------------------------------------

如下:变量在当前环境now 内部环境f1 内部深层环境f2 f3…都起作用的现象形成了一个链条
这个链条就成为作用域链
// 变量 banji的访问就可以看做一条作用域链

    var banji="php0609";

    console.log('班号:'+banji);

    function  f1(){ 
        console.log('f1:'+banji);// 能访问到班级 banji变量为全局变量 可以访问到
        function  f2(){
            console.log('f2:'+banji);
            function f3(){
                console.log('f3:'+banji);
            }
            f3();//能访问
        }
        f2();//能访问
    }
    f1();//能访问

// ------------------------------------------------

    // 变量必须先声明后使用  (函数由于有 “预加载 ” 可以不遵循此规则)

    // 同名变量和函数同时存在的情况   
     
    // var  subject="php"; //2
    // console.log(subject);
    // subject();//3 

    // function subject(){ //1 数字表示顺序 
    //     console.log("function sub ");
    // }

// ------------------------------------------------
// 内部环境可以访问外部环境的变量 反之不然

    var  week="Sunday";
    function fff1(){
        console.log('星期:'+week);
    }

    function fff2()
    {
        var week="monday"; //只能给fff2使用和访问  他是个局部变量 
        fff1(); //fff1无论在任何地方调用 就只能访问到Sunday的信息
    }

    fff2();  //Sunday 这是两个函数的共同环境

// -------------------------------------------------

    var  sub="123";
    function t1(){
        console.log("科目:"+sub);
    }

    t1();
    sub="345";
    t1();

</script>

```

作用 内部环境可以访问外部环境的变量 反之不然

变量的作用域是声明是决定的,而不是运行时

环境的定义: 每个函数内部都是一个环境  最外边是一个全局环境 
两种类型的环境 : 函数环境 和外部环境  

 -->
Document

// ------------------------------------------------
// 变量 banji的访问就可以看做一条作用域链

    var banji="php0609";

    console.log('班号:'+banji);

    function  f1(){ 
        console.log('f1:'+banji);// 能访问到班级 banji变量为全局变量 可以访问到
        function  f2(){
            console.log('f2:'+banji);
            function f3(){
                console.log('f3:'+banji);
            }
            f3();//能访问
        }
        f2();//能访问
    }
    f1();//能访问

// ------------------------------------------------

    // 变量必须先声明后使用  (函数由于有 “预加载 ” 可以不遵循此规则)

    // 同名变量和函数同时存在的情况   
     
    // var  subject="php"; //2
    // console.log(subject);
    // subject();//3 

    // function subject(){ //1 数字表示顺序 
    //     console.log("function sub ");
    // }

// ------------------------------------------------
// 内部环境可以访问外部环境的变量 反之不然

    var  week="Sunday";
    function fff1(){
        console.log('星期:'+week);
    }

    function fff2()
    {
        var week="monday"; //只能给fff2使用和访问  他是个局部变量 
        fff1(); //fff1无论在任何地方调用 就只能访问到Sunday的信息
    }

    fff2();  //Sunday 这是两个函数的共同环境

// -------------------------------------------------

    var  sub="123";
    function t1(){
        console.log("科目:"+sub);
    }

    t1();
    sub="345";
    t1();

</script>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值