JavaScript中var和this定义变量的区别

JavaScript中var和this定义变量的区别

       在js中声明变量时可以使用var和this,但使用this的有很大一部分参考书是没有的,经过查阅相关资料总结如下:

       用var和this声明变量,存在一个作用域的问题。var是在当前作用域(scope)中声明一个变量,而this则是指向当前上下文(context)。

作用域很好理解,在函数里面,作用域就是执行var语句的那个函数,否则就是root(window或者global)。 上下文是在函数调用的时候决定的:

foo.bar() // 上下文是foo(this === foo)
foo['bar']() // 上下文是root
foo['bar'].apply(obj) // 上下文是obj
foo['bar'].call(obj) // 上下文是obj
作用域是一个执行的过程。

这里有个误区

用this声明的变量并不一定就是成员变量,在函数里用this声明变量时,首先得看当前的上下文,如果该方法是有其他对象在调用,则this指向的上下文为这个对象,如果就只是一个方法,则此时的上下文为window,this指向的上下文是window,这个时候声明的变量才是全局变量。
var net = new Object(); //定义一个全局变量
net.AjaxRequest = function(url,onload,onerror,method,params){
this.req = null; //this指向的是net
this.onload = onload;
this.onerror = (onerror)?onerror:this.defaultError;
this.loadDate(url,method,params);
}
....................
 
posted on 2017-12-26 11:28  Windy心梦无痕  阅读(3050)  评论(0编辑  收藏  举报