js和html全局变量,JavaScript全局变量与局部变量

js和html全局变量,JavaScript全局变量与局部变量原文:深入理解JavaScript的变量作用域在学习JavaScript的变量作用域之前,我们应当明确几点:JavaScript的变量作用域是基于其特有的作用域链的。JavaScript没有块级作用域。函数中声明的变量在整个函数中都有定义。1、JavaScript的作用域链首先看下下面这段代码:varrain=1;functionrainman(){varman=2;function…

大家好,又见面了,我是你们的朋友全栈君。

原文:深入理解JavaScript的变量作用域

在学习JavaScript的变量作用域之前,我们应当明确几点:JavaScript的变量作用域是基于其特有的作用域链的。

JavaScript没有块级作用域。

函数中声明的变量在整个函数中都有定义。

1、JavaScript的作用域链

首先看下下面这段代码:

var rain = 1;

function rainman(){

var man = 2;

function inner(){

var innerVar = 4;

alert(rain);

}

inner(); //调用inner函数

}

rainman(); //调用rainman函数

观察alert(rain);这句代码。JavaScript首先在inner函数中查找是否定义了变量rain,如果定义了则使用inner函数中的rain变量;如果inner函数中没有定义rain变量,JavaScript则会继续在rainman函数中查找是否定义了rain变量,在这段代码中rainman函数体内没有定义rain变量,则JavaScript引擎会继续向上(全局对象)查找是否定义了rain;在全局对象中我们定义了rain = 1,因此最终结果会弹出’1’。

作用域链:JavaScript需要查询一个变量x时,首先会查找作用域链的第一个对象,如果以第一个对象没有定义x变量,JavaScript会继续查找有没有定义x变量,如果第二个对象没有定义则会继续查找,以此类推。

上面的代码涉及到了三个作用域链对象,依次是:inner、rainman、window。

2、函数体内部,局部变量的优先级比同名的全局变量高。

var rain = 1; //定义全局变量 rain

function check(){

var rain = 100; //定义局部变量rain

alert( rain ); //这里会弹出 100

}

check();

alert( rain ); //这里会弹出1

3、JavaScript没有块级作用域。

这一点也是JavaScript相比其它语言较灵活的部分。

仔细观察下面的代码,你会发现变量i、j、k作用域是相同的,他们在整个rain函数体内都是全局的。

function rainman(){

// rainman函数体内存在三个局部变量 i j k

var i = 0;

if ( 1 ) {

var j = 0;

for(var k = 0; k < 3; k++) {

alert( k ); //分别弹出 0 1 2

}

alert( k ); //弹出3

}

alert( j ); //弹出0

}

4、函数中声明的变量在整个函数中都有定义。

首先观察这段代码:

function rain(){

var x = 1;

function man(){

x = 100;

}

man(); //调用man

alert( x ); //这里会弹出 100

}

rain(); //调用rain

上面得代码说明了,变量x在整个rain函数体内都可以使用,并可以重新赋值。由于这条规则,会产生“匪夷所思”的结果,观察下面的代码。

var x = 1;

function rain(){

alert( x ); //弹出 ‘undefined’,而不是1

var x = ‘rain-man’;

alert( x ); //弹出 ‘rain-man’

}

rain();

是由于在函数rain内局部变量x在整个函数体内都有定义( var x= ‘rain-man’,进行了声明),所以在整个rain函数体内隐藏了同名的全局变量x。这里之所以会弹出’undefined’是因为,第一个执行alert(x)时,局部变量x仍未被初始化。

所以上面的rain函数等同于下面的函数:

function rain(){

var x;

alert( x );

x = ‘rain-man’;

alert( x );

}

5、未使用var关键字定义的变量都是全局变量。

function rain(){

x = 100; //声明了全局变量x并进行赋值

}

rain();

alert( x ); //会弹出100

这也是JavaScript新手常见的错误,无意之中留下的许多全局变量。

6、全局变量都是window对象的属性

var x = 100 ;

alert( window.x );//弹出100

alert(x);

等同于下面的代码

window.x = 100;

alert( window.x );

alert(x)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131252.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月12日 下午5:46
下一篇 2022年6月12日 下午5:46


相关推荐

  • java实现将图片读取成base64字符串,将base64字符串存储为图片。

    java实现将图片读取成base64字符串,将base64字符串存储为图片。全栈工程师开发手册(作者:栾鹏)java教程全解java实现将图片读取成base64字符串,将base64字符串存储为图片。将图片转化为字符串以后,由于字符串更方便在网络上通过ajax传输、在网络web前台和后台间进行传输。importsun.misc.BASE64Decoder;importsun.misc.BASE64Encoder;图片转化成base64字符串

    2025年8月2日
    4
  • python编译pyc文件

    python编译pyc文件什么是 pyc 文件 pyc 是一种二进制文件 是由 py 文件经过编译后 生成的文件 是一种 bytecode py 文件变成 pyc 文件后 加载的速度有所提高 而且 pyc 是一种跨平台的字节码 是由 python 的虚拟机来执行的 这个是类似于 JAVA 或者 NET 的虚拟机的概念 pyc 的内容 是跟 python 的版本相关的 不同版本编译后的 pyc 文件是不同的 2 5 编译的 pyc 文件 2 4 版本的 python 是无法执行的 什么是 pyo 文件 pyo 是优化编译后的程序 python O 源文件即可将源程序编译为 pyo 文件什

    2026年3月18日
    2
  • 【前端】HTML底部返回顶部悬浮按钮

    【前端】HTML底部返回顶部悬浮按钮CSS样式:.back-to{ bottom:55px; overflow:hidden; position:fixed; right:10px; width:110px; z-index:999; } .back-to.back-top{ background:url(“./imag…

    2022年7月13日
    22
  • 操作系统中的堆栈区别

    操作系统中的堆栈区别堆和栈是两种内存分配的统称 一 栈栈会存放函数的局部变量 函数的返回地址等 栈有 LIFO 后进先出 的特点 栈由操作系统分配 自动回收 栈的大小受到限制 在 x86 体系下 栈一般通过 esp 指向栈帧顶部 ebp 指向底部不断的嵌套或者为局部变量分配空间 可能导致栈溢出 这时候会触发一个异常在执行完一个函数的时候 其中的变量都会从堆栈中弹出 无需亲自管理内存 变量会自动分配和释放

    2026年3月17日
    2
  • 【大话设计模式】—— 模板方法模式

    【大话设计模式】—— 模板方法模式

    2021年12月8日
    69
  • vimrc配置_vim环境配置

    vimrc配置_vim环境配置博文背景写代码没vim难受,装个vim它对于快捷键的设置并不能和visualstudio一样很方便地设置将所有快捷键映射到vim插件,所以记录配置后的文件非常有必要。具体操作切换vim插件状态的快捷键设置:文件路径:C:\Users\Administrator\AppData\Roaming\JetBrains\WebStormXXX\options\vim_settings.xml文件内容:<application><componentname=”VimEdito

    2026年4月15日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号