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知识库 -> JS day13 ES6 -> 正文阅读

[JavaScript知识库]JS day13 ES6

21.let

? ? ?let用来声明变量,它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效

2.let的特点:

?1.变量必须先定义后使用:

a = 123;//Cannot access 'a' before initialization(报错)
	let a;

分析:虽然a在内存中,但是当你在let a 之前访问a时,根据ECMAScript定义,虚拟机会阻止的访问!

2.变量不能重复定义:

 let a = 1;
 let a = 2;//Identifier 'a' has already been declared(报错)

分析:a被定义两次,引发冲突。

3.块级作用域:

 let a = 666;
	console.log(a);//666
	{
		let a = 123;
		console.log(a);//123
	}

分析:在该块的范围内,才能使用该变量,且该变量不会消失。

4.暂时性死区:

 let a = 2;
  {
	let a = 1;
	console.log(a);//1
   }
   console.log(a);//2

分析:作用域不同的情况下,当内部变量与外部变量同名时,内部变量屏蔽外部变量

3.const:

? ?const命令用来声明常量,一旦声明,其值就不能改变。也就是只读变量。(只能读,不能改)

4.const的特点:

1.const修饰变量为只读变量

2.const必须先定义后使用

3.不能重复定义

4.块级作用域

5.被const修饰的变量必须初始化

*****注意事项:const修饰的变量名一般大写(习惯而已)

5.this:函数体内的一个内置对象(只能在函数体里使用)

1.this与事件连用:this代表触发该事件的元素

 document.onclick = function(){
	 	console.log(this);//document
	}

2.与普通函数连用:this代表调用该函数的对象

function fun(){
		this.document.write("heihei");
	}
	
	window.fun();

上面this代表的就是window。

6.bind:

功能:修改某个函数的this指向

参数:bind(被修改的this指向)

注意事项:bind是函数对象的一个成员函数,通常用来修饰匿名函数

let oBox = document.querySelector("#box");
	
	document.onclick = function(){
		this.style.display = "none";
	}.bind(oBox);

this就变成了oBox,当点击盒子的时候盒子就会消失(this由document变成了oBox)

7.for....in和for....of的区别:

for.....in:遍历下标

for.....of:遍历元素内容(通常用于遍历与set和map)当为有下标的时候用

let?strArr = ["heihei","haha","laowang"];

????for(let index in strArr){ //遍历下标
????????console.log(strArr[index]);
????}
????for(let t of??strArr){ //便利值
????????console.log(t);
????}

8.字符串扩展方法(ES6):判断字符串是否包含在另一个字符串中

1.str.includes(参数):

返回布尔值,表示是否找到了参数字符串。

2.str.startsWith(参数):

返回布尔值,参数是否在源字符串的头部。

3.str.endsWith(参数):

返回布尔值,参数是否在源字符串的尾部。

9.JSON.parse和JSON.stringify

1.json对象->字符串

let json = {"name":"老张","age":28};
let str = JSON.stringify(json);
 console.log(str,typeof str);

2.字符串—>json对象

 let str = '{"name":"老张","age":28}';
	 let json = JSON.parse(str);
	for(let index in json){
	 	console.log(json[index]);
	 }

10.箭头函数:匿名函数的另一种写法

let fun = ()=>{
		console.log("heihei");
	}
	
	fun();

注意事项:

1.当箭头函数只有一个参数时可以省略();

let f1 = a => {
		console.log(a);
	}
	
	f1(123);

2.当函数体只有一个语句时,可以省略{}

let f2 = a =>  console.log(a);
	f2(456);

?3.函数的参数的默认值


	 function f4(a=999,b=777){
	 	console.log(a,b);
	 }
	
	 f4(123);
	
	//箭头函数的this问题
	
	let obj = {
		"name":"老高",
		"fun":function(){
			console.log(this);
		},
		//箭头函数是没有this的,它的this是上级代码块的this(说明白就是该箭头函数所在作用域的this)
		"fun1":()=>{
			console.log(this);
		}
	}
	
	obj.fun();
	obj.fun1();

11.jiegou赋值:

解构赋值解析结构进行赋值?

let [x,y,z] = [1,2,3];
	
	console.log(x,y,z);

去掉json对象的前缀:

let json = {
		"name":"老王",
		"age":888
	}
	
	let {name,age} = json;
	
	console.log(name,age);

交换2个变量的值:


	let a = 123;
	let b = 456;
	
	[a,b] = [b,a];
	
	console.log(a,b);
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-26 10:04:39  更:2021-09-26 10:05:10 
 
开发: 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 19:40:47-

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