分享
 
 
 

JavaScript中的关键字“VAR”使用详解

王朝html/css/js·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

JScript的语法教程里面说在声明变量时忽略var要害字是完全合法的。但是事实经常又证实想当然的结果是不可靠的。

看看下面这几个例子的结果就知道问题了:

<script language="javascript">

var var00 = 0;

document.write(var00 + '<br>');

var var01 = 1;

function foo()

{

document.write(var01);

var var01 = 1;

}

foo();

</script>

<script language="Javascript">

var00 = 0;

document.write(var00 + '<br>');

var01 = 1;

function foo()

{

document.write(var01);

var01 = 1;

}

foo();

</script>

<script language="javascript">

var00 = 0;

document.write(var00 + '<br>');

var01 = 1;

function foo()

{

document.write(var01);

var var01 = 1;

}

foo();

</script>

这三个例子的执行结果分别是:

Results#region Results

No.1

0

undefined

No.2

0

1

No.3

0

undefined

#endregion

原来JavaScript的变量也是有作用域的,只是它非常的笼统,就分为全局变量和函数变量。在第二个例子中得到0和1,是因为所有的变量都是全局变量,而且那个语句块一共就定义了两个变量。而第一个第三的函数外全局变量,确实说明var要害字有没有都没有关系。而函数内的var要害字就很要害了,它说明第二个var01是函数内的变量,所以在初始化var01前输出自然就是'undefined'了。

那么函数里面是不是就屏蔽掉了全局的var01了呢?我们知道在C/C++可以使用::去访问全局变量,那么JavaScript可不可以呢?这里其实我们只要明白了全局变量到底是什么东西,就好弄了。原来全局变量都是动态添加到Window对象的实例window上的属性而以,所以我们只要在函数内用:document.write(window.var01);就可以取到其值1了。同时在这个上下文中,function内的this也是指向的window实例,我们也可以把引用写成:this.var01。

顺便说一下,重看JScript教程时,它说变量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'却也可以作为变量名字符,而且还可以用在开头,比如:$1234,更甚至于:$$$ 也是合法的变量名,faint。

<script type="text/javascript">

<!--

//这样写js的语句块更好一些:)

-->

</script>

我想知道是不是.在调用一个函数时,程序执行顺序会先检查函数内部变量中,有没有要害字var. 然后中再根据检查结果给不同的变量付予不同的作用域和变量值.因为我看到在这三个函数中,var01变量都是在输出语句之后.

function get_global_var(___name)

{

return eval(___name);

}

function set_global_var(___name,___value)

{

eval(___name+"=___value");

}

var aa=11;

Test();

WScript.Echo(aa);//22

function Test()

{

var aa=33;

WScript.Echo(get_global_var("aa"));//11

set_global_var("aa",22);

WScript.Echo(get_global_var("aa"));//22

WScript.Echo(aa);//33

}

在上面的例子中this从来就没有指过Test,而一直都是WScript的实例。

假如我们写一个语句:var test = new Test(); 这时Test里的this就是指的Test的一个实例了,这个实例中假如要使用Global的变量,Lostinet给出的是一个方法。

不过最简单还是把global传入对象,这样定义Test:

function Test(global)

{

// ...

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有