关于JS作用域:全局作用域、局部作用域的详解

JS 全局作用域

全局作用域是指变量可以在当前脚本的任意位置访问,拥有全局作用域的变量也被称为“全局变量”,一般情况下拥有以下特征的变量具有全局作用域:

  • 最外层的函数和在最外层函数外面定义的变量拥有全局作用域;
  • 所有未定义直接赋值的变量拥有全局作用域;
  • 所有 window 对象的属性拥有全局作用域,例如 window.name、window.location、window.top 等。

示例代码如下:

  1. var str = “Hello World!”;
  2.  
  3. function myFun(){
  4. document.write(str); // 输出:Hello World!
  5. }
  6.  
  7. myFun();
  8. document.write(str); // 输出:Hello World!

实际情况下,所有具有全局作用域的变量都会被绑定到 window 对象中,成为 window 对象的一个属性,如下例所示:

  1. var str = “JavaScript”;
  2. document.write(str); // 输出:JavaScript
  3. document.write(window.str); // 输出:JavaScript
  4. document.write(str === window.str); // 输出:true

JS 局部作用域

在函数内部声明的变量具有局部作用域,拥有局部作用域的变量也被称为“局部变量”,局部变量只能在其作用域中(函数内部)使用。示例代码如下:

  1. function myFun(){
  2. var str = “Hello World!”;
  3. document.write(str); // 输出:Hello World!
  4. }
  5.  
  6. document.write(str); // 报错:str is not defined

在函数内定义的局部变量只有在函数被调用时才会生成,当函数执行完毕后会被立即销毁。

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片