全局作用域与函数作用域

作用域

  • 作用域指一个变量的作用的范围
  • 在JS中一共有两种作用域

全局作用域

  • 直接编写在script标签中的JS代码,都在全局作用域

  • 全局作用域在页面打开时创建,在页面关闭时销毁

  • 在全局作用域中有一个全局对象window(它代表的是一个浏览器的窗口),我们可以直接使用

  • 在全局作用域中:

    • 创建的变量都会作为window对象的属性保存
    • 创建的函数都会作为window对象的方法保存
  • 全局作用域中的变量都是全局变量

    • 在页面的任意的部分都可以访问的到

变量的声明提前

  • 使用var关键字声明的变量,会在所有的代码执行之前被声明(但是不会赋值),
    但是如果声明变量时不适用var关键字,则变量不会被声明提前

函数的声明提前

  • 使用函数声明形式创建的函数function函数( ){ }
    它会在所有的代码执行之前就被创建

函数作用域

函数作用域

  • 调用函数时创建函数作用域,函数执行完毕以后,函数作用域销毁
  • 每调用一次函数就会 创建一个 新的函数作用域,他们之间是互相独立的
  • 在函数作用域中可以访问到全局作用域的变量
    • 在全局作用域中无法访问到函数作用域的变量
  • 当在函数作用域操作一个变量时,它会先在自身作用域中寻找,如果有就直接使用
    • 如果没有则向上一级作用域中寻找,直到找到全局作用域,如果全局作用域中依然没有找到,则会报错ReferenceError

在函数作用域也有声明提前的特性,
使用var关键字声明的变量,会在函数中所有的代码执行之前被声明

在函数中,不适用var声明的变量都会成为全局变量

var c = 1;
function fun1(){
    console.log("c = "+c);
    var c = 2;
}
fun1();
//输出为c = undefined
var c = 1;
function fun1(){
    console.log("c = "+c);
    c = 2;
}
fun1();
//输出为c = 1
var c = 1;
function fun1(){
    c = 2;
}
fun1();
console.log("c = "+c);
//输出为c = 2
//定义形参就相当于在函数作用域中声明了变量
var a = 10;
function fun2(a){
    console.log(a);
}
fun2();
//输出为undefined
posted @   苏槿年  阅读(195)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示