10变量以及作用域

19 篇文章 0 订阅
本文详细介绍了JavaScript中的作用域概念,包括全局作用域、局部作用域和块级作用域,并强调了ES5之前没有真正的块级作用域。同时,讨论了作用域链以及变量和函数的提升机制,指出预解析过程中声明被提升但赋值不提升的特点。通过实例展示了变量和函数提升的运行逻辑,以及未使用`var`声明变量时的全局变量行为。
摘要由CSDN通过智能技术生成

javascript基础

作用域

作用域: 变量可以起作用的范围.

全局变量

在任何地方都可以访问到变量就叫做全局变量,对应全局作用域

局部变量

只在固定的代码区域内可以访问到的变量,对应局部作用域(函数作用域)

不使用var声明的变量是全局变量,不推荐.
局部变量退出作用域后就会被销毁,全局变量关闭页面或浏览器才会销毁

块级作用域

任何一对花括号({和})中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域。
在es5之前没有块级作用域的的概念,只有函数作用域,现阶段可以认为JavaScript没有块级作用域.

作用域链

只有函数可以制造作用域结构, 那么只要是代码,就至少有一个作用域, 即全局作用域。凡是代码中有函数,那么这个函数就构成另一个作用域。如果函数中还有函数,那么在这个作用域中就又可以诞生一个作用域。

将这样的所有的作用域列出来,可以有一个结构: 函数内指向函数外的链式结构。就称作作用域链。
// 案例1:
function f1() {
    function f2() {
    }
}

var num = 456;
function f3() {
    function f4() {    
    }
}

在这里插入图片描述

// 案例2
function f1() {
    var num = 123;
    function f2() {
        console.log(num); 
    }
    f2();
}
var num = 456;
f1();

在这里插入图片描述

预解析

javascript代码的执行是有浏览器中的javascript解析器来执行的.

javascript解析器执行javascript代码的时候,分为两个过程: 预解析过程和代码执行过程.

  • 预解析过程:

    把变量的声明提升到当前作用域的最前面,只会提升声明,不会提升赋值.

    把函数的声明提升到当前作用域的最前面,只会提升声明,不会提升作用.

    先提升var,再提升fuction.

案例:

//案例1
var a = 25;
function abc() {
  alert(a); 
  var a = 10;
}
abc();


// 案例2
console.log(a);
function a() {
  console.log('aaaaa');
}
var a = 1;
console.log(a);

变量提升

  • 变量提升

  • 定义变量的时候,变量的声明会被提升到作用域的最上面,变量的赋值不会提升。

  • 函数提升

    JavaScript解析器首先会把当前作用域的函数声明提前到整个作用域的最前面

// 1、-----------------------------------
var num = 10;
fun();
function fun() {
  console.log(num);
  var num = 20;
}
//2、-----------------------------------
var a = 18;
f1();
function f1() {
  var b = 9;
  console.log(a);
  console.log(b);
  var a = '123';
}
// 3、-----------------------------------
f1();
console.log(c);
console.log(b);
console.log(a);
function f1() {
  var a = b = c = 9;
  console.log(a);
  console.log(b);
  console.log(c);
}  
//a是局部变量,b/c是全局变量,使用了var后,就会变成局部变量,没有使用var就是全局变量.

var a = b = c = 9;
console.log(a);
console.log(b);
console.log©;
}
//a是局部变量,b/c是全局变量,使用了var后,就会变成局部变量,没有使用var就是全局变量.


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我以为自己很帅

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值