ES6-let和const命令+顶层对象和全局对象

2024-06-22 15:48

本文主要是介绍ES6-let和const命令+顶层对象和全局对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.let关键字

(1)语法规范

(2)作用

         a. 声明变量

         b.不能重复声明变量,可以修改其值

          c.不存在变量提升,临时性死区(函数内)

注:var声明的变量可以重新声明,可以修改其值;

let声明变量,var不可重复声明;

var声明变量,let不可重复声明;

2.块级作用域

(1):var声明变量,函数外声明为全局变量,for循环只是绑定了事件,没有执行function,因此每次循环输出的都是4,例子

<script>
//假如li有 4 个
var li=document.querySelectorAll('#List');
for(var i=0;i<li.length;i++){li[i].onclick=function(){console.log();}
}
</script>

(2):let声明变量,每次for循环都产生一块独立作用域,代替闭包的一些功能;

<script>
//假如li有 4 个
var li=document.querySelectorAll('#List');
for(var i=0;i<li.length;i++){li[i].onclick=function(){console.log();}
}
</script>

(3)哪些情况产生块级作用域:

for、if、else、while等代码块产生块级作用域;例子:

<script>
if(true){var a=100;let b=200;console.log(b);
}
console.log(a);//输出100
console.log(b);//显示没有定义,以为let块级作用域,只能在if能输出
</script>

3.const关键字

(1)作用:声明常量,命名为大写,例子:

<script>const DBNAME= "mydb";//声明变量console.log(DBNAME);
</script>

注:常量的值不能修改,定义一次即可,例:

<script>const DBNAME= "mydb"; //声明变量DBNAME = "myData"; //常量的值不能修改console.log(DBNAME); //输出显示错误
</script>

(2)特点:const声明的常量同样存在作用域(局部作用域、块级作用域、全局作用域)

例子一:

<script>function fn(){const DBNAME='123456';}fn();
console.log(DBNAME); //输出错误未定义,因为此时的const为局部作用域;
</script>

例子二:

<script>if(true){const DBNAME='123456';}console.log(DBNAME); //输出错误未定义,因为此时的const产生块级作用域,在if块级里写输出没有问题;
</script>

4.顶层对象和全局对象

ES6去掉顶层对象的概念;

(1)为了向下兼容,在全局作用域中使用var声明的变量和直接声明的函数仍然是顶层对象的属性和方法;

例子:

<script>var username = '小红';function fn(){console.log('我是函数fn');}console.log(window.username);//输出小红,window在浏览器中属于顶层对象,所有属性都属于他。全部变量和函数都属于顶层对象的属性和方法;同样window.fn();window.fn();
</script>

(2)使用let和const声明的变量不再输入顶层对象,不属于window顶层对象;

<script>let username = '小红';console.log(window.username);//输出错误,显示没有定义(window不存在的属性时输出未定义)同理const也是未定义
</script>

 

这篇关于ES6-let和const命令+顶层对象和全局对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1084723

相关文章

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

postgresql数据库基本操作及命令详解

《postgresql数据库基本操作及命令详解》本文介绍了PostgreSQL数据库的基础操作,包括连接、创建、查看数据库,表的增删改查、索引管理、备份恢复及退出命令,适用于数据库管理和开发实践,感兴... 目录1. 连接 PostgreSQL 数据库2. 创建数据库3. 查看当前数据库4. 查看所有数据库

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文