JavaScrip Zone


新发表

新评论

留言信息

链接收藏

『中国群落博客』

免费注册博客通道

快速登陆


JavaScript 变量范围

javascript 有两种变量范围:全局和局部。如果在任何函数定义之外声明了一个变量,则该变量为全局变量,且该变量的值在整个持续范围内都可以访问和修改。如果在函数定义内声明了一个变量,则该变量为局部变量。每次执行该函数时都会创建和破坏该变量;且它不能被该函数外的任何事物访问。

一个局部变量的名称可以与某个全局变量的名称相同,但这是完全不同和独立的两个变量。因此,更改一个变量的值不会影响另一个变量的值。在声明局部变量的函数内,只有该局部变量有意义。

var aCentaur = "a horse with rider,"; // aCentaur 的全局定义。

// javascript 代码,为简洁起见有省略。
function antiquities() // 在这个函数中声明了一个局部 aCentaur 变量。
{

// javascript 代码,为简洁起见有省略。
var aCentaur = "A centaur is probably a mounted Scythian warrior";

// javascript 代码,为简洁起见有省略。
aCentaur += ", misreported; that is, "; // 添加到局部变量。

// javascript 代码,为简洁起见有省略。
} // 函数结束。

var nothinginparticular = antiquities();
aCentaur += " as seen from a distance by a naive innocent.";

/*
在函数内,该变量的值为 "A centaur is probably a mounted Scythian warrior,
misreported; that is, ";在函数外,该变量的值为这句话的其余部分:
"a horse with rider, as seen from a distance by a naive innocent."
*/

很重要的一点是注意变量是否是在其所属范围的开始处声明的。有时这会导致意想不到的情况。

var aNumber = 100;
var withAdditive = 0;

withAdditive += aNumber; // withAdditive 现在是 100。
tweak();
withAdditive += aNumber; // withAdditive 现在是 200。

function tweak() {
var newThing = 0; // 显示声明 newThing 变量。
// 如果不注释下一条语句,将产生一个错误。
// newThing = aNumber;
// 下一条语句将值 42 赋给局部的 aNumber,该变量是隐式声明的。
aNumber = 42;
if (false) {
var aNumber; // 该语句永远不会执行。
aNumber = "Hello!"; // 该语句永远不会执行。
} // 条件语句结束。
} // 该函数定义结束。

被注释掉的语句试图将局部变量 aNumber 的值赋给局部变量 newThing 的值。尽管事实上在函数的其他地方定义了一个局部 aNumber 变量,并且因此在整个函数内都存在,这样做也不会成功。 aNumber 变量在代码中这条语句的位置处没有被赋值,因此是 undefined。


                                                                 2005-10-26 17:17:26

Posted by jser | 阅读全文() | 回复(0) | 引用通告() | 编辑

..................................................
博客的精神于写自己某一刻的思想或心动!
..................................................
当然要是你愿意就是拿来做记事本也可以!
..................................................
群落博客将提供全程免费服务!免费注册!
..................................................
欢迎您成为群落博客的成员!使用之前请先看系统帮助>>>>系统帮助
..................................................

免费注册群落博客【点击完成注册】
..................................................

发表评论:

    昵称:
    密码: (游客无须输入密码)
    主页:
    标题: