博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS全局变量VAR和THIS
阅读量:7079 次
发布时间:2019-06-28

本文共 1268 字,大约阅读时间需要 4 分钟。

(注意)JS全局变量VAR和THIS

很多人都觉得在javascript声明一个变量,加var和不加var没有什么区别,实际上是一个错误的观点,如果在函数外面,也就是说在window区域加不加var确实是一样,因为都会是全局变量的效果,而如果在函数内部,加var就是局部变量,不加是全局变量。

function test(){     var1 = 2;   alert(var1);      }  
test();   alert(var1); 这样可以显示为2 function test(){     var var1 = 2;   alert(var1);      }   test();   alert(var1);
则为变量未定义错误
this多用于函数内部,它永远指向调用他的那个对象,看看下面的例子就明白了
var test={    a:"test",            // a省略了this,不是私有的(var);    msg:function(){            // msg省略了this,不是私有的(var);      a="1234";            // a为全局变量,可以在最外边尝试alert(a),可以得到1234      alert(this.a);      var msg1= function(){         alert(this.a);      }      msg1();    }
} test.msg(); 这样会分别显示 "test" ,"1234". 

 

再举一个例子:

var name = "The Window";    var object = {     name : "My Object",  

  getNameFunc : function(){      return function(){       return this.name;        };      }    };  
alert(object.getNameFunc()());  //The Window

但this也不是这么简单,在看看下面的例子 function test1()   {     this.var01 = "test"; }

function test2()   {   alert(var01); }
var a= new test1(); test1(); test2(); alert(a.var01);
都可以得到"test".
可以发现var01变量既是一个全局变量,又是test1内的成员变量。也就是说,如果在函数内部用this定义的变量,如果这个函数你不是直接来运行,而是作为一个类来new的话,虽然函数也要执行一遍,但里面的this定义的 变量是作为类的成员变量来定义的,也就是一个局部变量,上面的测试代码,如果去掉test1();  test2()运行就是未定义变量错误了。
说到变量,最后提一下js变量无类型的说法,这个说法本身没有错,但js变量无类型,这话很模糊,有的人会理解成js 里面没有数据类型。这显然是错误的,js 里面也有数字,字符,布尔,类等数据类型。说变量无类型,指的是刚定义一个变量的时候,这个变量是没有类型的,当你给它赋值的时候,值是什么类型,那这个变量就是什么类型了

转载地址:http://psdml.baihongyu.com/

你可能感兴趣的文章
Java 多线程程序设计
查看>>
SQL--类型转换
查看>>
VGG_19 train_vali.prototxt file
查看>>
获取文件或是文件夹的大小和占用空间
查看>>
libssh2进行远程运行LINUX命令
查看>>
Android Gson深入分析
查看>>
Android中自动跳转到系统设置界面
查看>>
树后台数据存储(採用webmethod)
查看>>
Android利用Fiddler进行网络数据抓包【怎么跟踪微信请求】
查看>>
memcached系列之二
查看>>
树的左旋与右旋
查看>>
Atitit. 如何判断软件工程师 能力模型 程序员能力模型 项目经理能力模型...
查看>>
每周算法讲堂,二分法
查看>>
2016第8周五
查看>>
CSS3文本溢出显示省略号
查看>>
zookeeper系列之通信模型(转)
查看>>
js动态判断密码强度&&实用的 jQuery 代码片段
查看>>
.Net开源SqlServer ORM框架SqlSugar整理
查看>>
JQuery在循环中绑定事件的问题详解
查看>>
SOCKS 5协议详解(转)
查看>>