IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> ES6学习-- LET -> 正文阅读

[JavaScript知识库]ES6学习-- LET

特点

(1)变量声明不能重复

(2)变量具有块级作用域

(3)变量不存在变量提升,即先使用后声明

(4)?不影响作用链

特点案例:

(1)变量声明不能重复,重复时报错,停止脚本?Uncaught SyntaxError: Identifier 'b' has already been declared

            // 变量声明不能重复
            var a = 0
            var a = 10
            console.log(a)
            // 不加下面的内容时,此处可以输出,添加下面的内容时输出为b has already been declared,连10都不会输出了
            let b = 10;
            let b = 11;
            console.log(b)
//Uncaught SyntaxError: Identifier 'b' has already been declared

(2)块级作用域

			// 块级作用域
            {
                var testBlockVar = '测试块';
                let testBlockLet = '测试块';
            }
			console.log(testBlockVar)
			console.log(testBlockLet)

回显如下,此处前面的是可以执行的,let冲突的时候是都不会执行
在这里插入图片描述

?(3)变量提升? --? 未声明变量之前直接使用

            console.log(testUpLet)
            console.log(testUpVar)
            var testUpVar = '测试变量提升';
            let testUpLet = '测试变量提升'

注:let可以在声明之前使用,值为undefined,let的会报错,并且在报错的地方直接停止程序

?(4)不影响作用链? --? 会向上找let的变量

            {
                let testGlobal = '尚硅谷外';
                let testGlobal1 = '尚硅谷1'

                function f() {
                    let testGlobal = '尚硅谷内';
                    console.log(testGlobal)
                    console.log(testGlobal1)
                }

                f();
            }

会向上寻找变量,如果内部定义一个相同的变量,则使用自己同级的变量

?典型问题

(1)let修改块作用域

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<title>Title</title>
		<style>
			.item {
				height: 50px;
				width: 50px;
				border: 1px solid black;
				display: inline-block;
			}
		</style>
	</head>
	<body>
		<div class="pageheader">点击切换颜色</div>
		<div class="item"></div>
		<div class="item"></div>
		<div class="item"></div>
		<div class="item"></div>
		<script>
            let items = document.getElementsByClassName('item')
            for (var i = 0; i < items.length; i++) {
                items[i].onclick = function () {
                    // this.style.backgroundColor = 'pink'; // 正确写法
                    items[i].style.backgroundColor = 'pink' // 错误写法,会抛出 Cannot read properties of undefined (reading 'style') at HTMLDivElement.items.<computed>.onclick
                }
            }
            // 错误的原因解析如下,因为function在click的时候才去执行,此时i的值是全局的,已经变成了3,因此找不到items[3],修改成let时,点击时,会找自己的块,如下的每个块,function中没有,则找到块内的上面,let i = 0/1/2/3
            {
                var i = 0;
                items[0].onclick = function () {
                    // this.style.backgroundColor = 'pink'; // 正确写法
                    items[i].style.backgroundColor = 'pink' // 错误写法,会抛出 Cannot read properties of undefined (reading 'style') at HTMLDivElement.items.<computed>.onclick
                }
            }
            {
                var i = 1;
                items[1].onclick = function () {
                    // this.style.backgroundColor = 'pink'; // 正确写法
                    items[i].style.backgroundColor = 'pink' // 错误写法,会抛出 Cannot read properties of undefined (reading 'style') at HTMLDivElement.items.<computed>.onclick
                }
            }
            {
                var i = 2;
                items[2].onclick = function () {
                    // this.style.backgroundColor = 'pink'; // 正确写法
                    items[i].style.backgroundColor = 'pink' // 错误写法,会抛出 Cannot read properties of undefined (reading 'style') at HTMLDivElement.items.<computed>.onclick
                }
            }
            {
                var i = 3;
                items[3].onclick = function () {
                    // this.style.backgroundColor = 'pink'; // 正确写法
                    items[i].style.backgroundColor = 'pink' // 错误写法,会抛出 Cannot read properties of undefined (reading 'style') at HTMLDivElement.items.<computed>.onclick
                }
            }


		</script>
	</body>
</html>

(2)上面案例闭包修改

注:可以看出立即执行函数会形成一个自己的封闭空间,其不会被外部的其他变量影响,其实这个如果再有一个return的话就是一个标准的闭包了。

		<script>
            let items = document.getElementsByClassName('item')
            for (var i = 0; i < items.length; i++) {
                (function (i) {
                    items[i].onclick = function () {
                        items[i].style.backgroundColor = 'pink';
                    }
                })(i)
            }

		</script>

闭包函数拆解开,类似于下图,可以看出,传参在函数内部有自己的作用域,i已经不在使用for循环的块级域。

		<script>
            let items = document.getElementsByClassName('item')

            function setOnclick(i) {
                items[i].onclick = function () {
                    items[i].style.backgroundColor = 'pink';
                }
            }

            for (var i = 0; i < items.length; i++) {
                setOnclick(i)
            }

		</script>

(3)如果闭包不传参,使用全局参数var呢

            let items = document.getElementsByClassName('item')
			var i = 0;

            function setOnclick() {
                items[i].onclick = function () {
                    console.log(i)
                    items[i].style.backgroundColor = 'pink';
                }
            }

            for (var i = 0; i < items.length; i++) {
                setOnclick()
            }
            console.log(i)

很明显了,和上面的一样,每次for循环已经把i的值加到了4,后续点击的时候setOnclick没有传参,使用全局参数i = 4

?

类似案例如下:

//情况1
//闭包函数的外部函数没有初值
var i = 0;  //全局变量

function outerFn(){
  function innnerFn(){
       i++;
       console.log(i);
  }
  return innnerFn;
}

var inner1 = outerFn(); //闭包函数的外部函数也没有初值,用的全局变量
var inner2 = outerFn(); 
//两个函数共用同一个全局变量
inner1();   //1
inner2();   //2
inner1();   //3
inner2();   //4

//情况2
//闭包函数的外部函数有初值
function outerFn(){
var i = 0;
  function innnerFn(){
      i++;
      console.log(i);
  }
  return innnerFn;
}
var inner1 = outerFn();
var inner2 = outerFn();
inner1();   //1
inner2();   //1
inner1();   //2
inner2();   //2

(4)终极问题? --?计程车问题

暂时没看懂此问题容易出错的在哪,后续补充

            let car = (function () {
                let start = 12
                let total = 0
                return {
                    price(n) {
                        if (n <= 3) {
                            total = start;
                        } else {
                            total = start + (n - 3) * 5
                        }
                        return total
                    },
                    jam(flag) {
                        return flag ? total + 10 : total;
                    }
                }
            })()
            console.log(car.price(3))
            console.log(car.jam(true))
            console.log(car.jam(false))

参考资料:尚硅谷Web前端ES6教程,涵盖ES6-ES11

? ? ? ? ? ? ????????立即执行函数

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-06-18 23:21:39  更:2022-06-18 23:21:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 11:13:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码