变量的作用范围

变量的作用域:变量的作用范围
             根据作用域不同,将变量分为以下两类:
             (1)全局变量
                     1.在函数外部定义的变量
                     2.变量定义时未使用var关键字
                     3.window对象的属性
             (2)局部变量
                     1.在函数内部定义的变量(包含参数位置)

定义变量放在函数内部则

函数内部X1属于函数内部变量,外界获取不到,所以会报错
y1,z1系统默认全局变量,所以不报错

报错后边不执行后面的

 (function(){
            var x1 =y1=z1=1;
            
         })();
 console.log(y1); //输出1
 console.log(x1);//报错
 console.log(z1);//前边报错后边不执行 如果在报错前输出1;


如果给变量单独赋值(局部变量全局输出)则全部报错

函数内部手动定义的属于函数内部定义,外界获取不到,所以会报错
        

(function(){
            var x1=1;
            var y1=1;
            var z1=1;

         })();
            console.log(y1); //报错
            console.log(x1);//报错
            console.log(z1);//报错    

定义变量放在函数内部(局部变量局部输出)则都不会报错

函数内部手动定义的属于函数内部定义,内部可以接收到
        

(function(){
            // var x1 =y1 =z1=1;
            var x1 =y1 =z1=1;
            console.log(y1); //输出1
            console.log(x1);//输出1
            console.log(z1);//输出1

         })();

             总结:
                 全局变量生命周期较长,占用内存时间长,不利于回收
                 局部变量生命周期较短,当函数调用完毕时,等待回收,满足快速释放

                 推荐多使用局部变量,少使用全局变量

猜你喜欢

转载自blog.csdn.net/weixin_44390947/article/details/86477344