JavaScript 中 var let 和 const

let 和 const是es6当中新增的关键字。

let 声明的变量只在 let 命令所在的代码块内有效。
const 声明一个只读的常量,一旦声明,常量的值就不能改变。

全局变量

在函数外声明的变量作用域是全局的,其在js的任何部分都能访问。

var a = "abcdef";
//可以在这里使用a变量
function myfunction(){
	//也可以在这里使用a变量
}

局部变量

在函数内声明的变量作用域是局部的。
函数内使用 var 声明的变量只能在函数内容访问,如果不使用 var 则是全局变量

//不能再这里使用a变量
function myfunction(){
	var a = "abcdef";
	//可以在这里使用a变量
}
//不能再这里使用a变量

JavaScript 块级作用域(Block Scope)

使用 var 关键字声明的变量不具备块级作用域的特性,它在 {} 外依然能被访问到。

{ 
    var a = 2; 
}
// 这里可以使用 a 变量

在 ES6 之前,是没有块级作用域的概念的。
ES6 可以使用 let 关键字来实现块级作用域。
let 声明的变量只在 let 命令所在的代码块 {} 内有效,在 {} 之外不能访问。

{ 
    let a = 2;
}
// 这里不能使用 a 变量

因此,使用var关键字时,重新声明变量可能会产生问题。

var a = 2;
//这里a=2
{
	var a = 3;
	//这里a=3
}
//这里a=3

使用let关键字解决这一问题。

var a = 2;
//这里a=2
{
	let a = 3;
	//这里a=3
}
//这里a=2

循环作用域

var i = 5;
for (var i = 0; i < 10; i++) {
    // 一些代码...
}
// 这里输出 i 为 10
var i = 5;
for (let i = 0; i < 10; i++) {
    // 一些代码...
}
// 这里输出 i 为 5

函数体内使用 var 和 let 关键字声明的变量其作用域是局部的
函数体外或代码块外使用 var 和 let 关键字声明的变量其作用域是全局的

// 使用 var
function myFunction() {
    var a= "abcdef";   // 局部作用域
}

// 使用 let
function myFunction() {
    let a= "abcdef";    //  局部作用域
}

// 使用 var
var x = 2;       // 全局作用域

// 使用 let
let x = 2;       // 全局作用域

HTML 代码中使用全局变量

在 JavaScript 中, 全局作用域是针对 JavaScript 环境。
在 HTML 中, 全局作用域是针对 window 对象。
使用 var 关键字声明的全局作用域变量属于 window 对象,使用 let 关键字声明的全局作用域变量不属于 window 对象

var a= "abcdef";
// 可以使用 window.a  访问变量

let a= "abcdef";
// 不可以使用 window.a  访问变量

重置变量

使用 var 关键字声明的变量在任何地方都可以修改,可以使用 lvar 关键字来重置 var 关键字声明的变量。

var a = 2;  //此时a=2
var a = 3;  //此时a=3

在相同的作用域或块级作用域中,不能使用 let 关键字来重置 var 关键字声明的变量,不能使用 var 关键字来重置 let 关键字声明的变量,不能使用 let 关键字来重置 let 关键字声明的变量。

var a = 2;       // 合法
let a = 3;       // 不合法
{
    var a = 4;   // 合法
    let a = 5   // 不合法
}

let a = 2;       // 合法
var a = 3;       // 不合法
{
    let a = 4;   // 合法
    var a = 5   // 不合法
}
let a = 2;       // 合法
let a = 3;       // 不合法
{
    let a = 4;   // 合法
    let a = 5   // 不合法
}

let 关键字在不同作用域,或不同块级作用域中是可以重新声明赋值的:

let x = 2;       // 合法
{ 
   let x = 3;   // 合法
}
{
    let x = 4;   // 合法
}

变量提升

在js中,函数及变量的声明都将被提升到函数的最顶部。
var 关键字定义的变量可以在使用后声明,也就是变量可以先使用再声明。

下面两种写法结果相同。

x = 5; // 变量 x 设置为 5
elem = document.getElementById("demo"); // 查找元素
elem.innerHTML = x;                     // 在元素中显示 x
var x; // 声明 x
var x; // 声明 x
x = 5; // 变量 x 设置为 5
elem = document.getElementById("demo"); // 查找元素
elem.innerHTML = x;                     // 在元素中显示 x

JavaScript 只有声明的变量会提升,初始化的不会。

下面两种写法结果不同。

var x = 5; // 初始化 x
var y = 7; // 初始化 y
elem = document.getElementById("demo"); // 查找元素
elem.innerHTML = x + " " + y;           // 显示 x 和 y 5 7
var x = 5; // 初始化 x
elem = document.getElementById("demo"); // 查找元素
elem.innerHTML = x + " " + y;           // 显示 x 和 y  5 undefined 
var y = 7; // 初始化 y
=============================
相当于
var x = 5; // 初始化 x
var y;     // 声明 y
elem = document.getElementById("demo"); // 查找元素
elem.innerHTML = x + " " + y;           // 显示 x 和 y 5 undefined 
y = 7;    // 设置 y 为 7

但是!!!let 关键字定义的变量则不可以在使用后声明,也就是变量需要先声明再使用。

JavaScript 严格模式(strict mode)不允许使用未声明的变量。它是一个字面量表达式,通过在脚本或函数的头部添加 use strict; 表达式来声明。

"use strict";
x = 3.14;       // 报错 (x 未定义)
===================================
"use strict";
myFunction();
function myFunction() {
    y = 3.14;   // 报错 (y 未定义)
}
====================================
x = 3.14;       // 不报错
myFunction();
function myFunction() {
   "use strict";
    y = 3.14;   // 报错 (y 未定义)
}

const 关键字

const 用于声明一个或多个常量,声明时必须进行初始化,且初始化后值不可再修改:

const PI = 3.141592653589793;
PI = 3.14;      // 报错
PI = PI + 10;   // 报错

const定义常量与使用let 定义的变量相似:
二者都是块级作用域
不能和它所在作用域内的其他变量或函数拥有相同的名称
两者还有以下两点区别:
const声明的常量必须初始化,而let声明的变量不用。
const 定义常量的值不能通过再赋值修改,也不能再次声明。而 let 定义的变量值可以修改。

var x = 10;
// 这里输出 x 为 10
{ 
    const x = 2;
    // 这里输出 x 为 2
}
// 这里输出 x 为 10

const 声明的常量必须初始化:
// 错误写法
const PI;
PI = 3.14159265359;

// 正确写法
const PI = 3.14159265359;

const 的本质: const 定义的变量并非常量,并非不可变,它定义了一个常量引用一个值。使用 const 定义的对象或者数组,其实是可变的

// 可以创建常量对象
const car = {type:"Fiat", model:"500", color:"white"};
// 可以修改属性:
car.color = "red";
// 可以添加属性
car.owner = "Johnson";
================================
//但是其不能对常量对象重新赋值
const car = {type:"Fiat", model:"500", color:"white"};
car = {type:"Volvo", model:"EX60", color:"red"};    // 错误
// 可以创建常量数组
const cars = ["Saab", "Volvo", "BMW"];
// 可以修改元素
cars[0] = "Toyota";
// 可以添加元素
cars.push("Audi");
====================================
//但是不能对常量数组重新赋值:
const cars = ["Saab", "Volvo", "BMW"];
cars = ["Toyota", "Volvo", "Audi"];    // 错误

重置变量

在相同的作用域或块级作用域中,不能使用 const 关键字来重置 var ,let,const关键字声明的变量

const x = 2;       // 合法
const x = 3;       // 不合法
x = 3;             // 不合法
var x = 3;         // 不合法
let x = 3;         // 不合法
{
    const x = 2;   // 合法
    const x = 3;   // 不合法
    x = 3;         // 不合法
    var x = 3;     // 不合法
    let x = 3;     // 不合法
}

const 关键字在不同作用域,或不同块级作用域中是可以重新声明赋值的:

const x = 2;       // 合法
{
    const x = 3;   // 合法
}
{
    const x = 4;   // 合法
}

const 关键字定义的变量也不可以在使用后声明,也就是变量需要先声明再使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值