首页 > Web开发 > 详细

js全局访问局部变量

时间:2016-06-18 12:43:15      阅读:230      评论:0      收藏:0      [点我收藏+]

1、

  在函数内使用this.name(变量名)的方式赋值,当函数作为普通函数调用时,在函数外部可以直接访问到,这是因为这里的this指向window:

    function fn(){
        var r = 2 ;
        this.ss = 0;
        this.sum=function(num1,num2){
          return (num1+num2)*r;
        };
    }
    fn();
    //var b = new fn();
    console.log(ss);                //0
    console.log(window.sum(1,2));    //6
    console.log(sum(1,2));            //6

   当函数作为方法函数调用时,情况又有所不同,这时候this指向发生变化,指向自身:

 

    function fn(){
        var r = 2 ;
        this.ss = 0;
        this.sum=function(num1,num2){
          return (num1+num2)*r;
        };
    }
    
    var b = new fn();
/*    
    console.log(ss);                //error 报错
    console.log(window.sum(1,2));    //error 报错
    console.log(sum(1,2));            //error 报错
*/    
    //可以通过实例访问
    console.log(b.ss);                //0
    console.log(b.sum(1,2));    //6

 

2、

    var a ;
    function fn2(){
        var b = 0;
        return b ;
    };
    a = fn2();
    console.log(a); //0

 

js全局访问局部变量

原文:http://www.cnblogs.com/xiaowan-/p/5595888.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!