前端学习之 ES6-ES11

2023-11-22 07:11
文章标签 学习 前端 frontend es6 es11

本文主要是介绍前端学习之 ES6-ES11,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ES6

let

1.变量不能重复声明

let 声明的变量名不能重复,避免变量污染

let star = '罗志祥';
let star = '小猪';
console.log(star);

在这里插入图片描述
var声明的变量可以重复,后面的值会覆盖前面的值

var star = '罗志祥';
var star = '小猪';
console.log(star);

在这里插入图片描述

2.块级作用域

如果在块级作用域中使用let声明变量,则有块级作用域

{let myName= '王思聪';
}
console.log(myName);

在这里插入图片描述
在块级作用域中使用var声明变量,没有块级作用域

{var myName= '王思聪';
}
console.log(myName);

在这里插入图片描述

3.不存在变量提升

在let声明变量前,先打印变量,会报错,不存在变量提升。

console.log(song);
let song = '日不落';

在这里插入图片描述
在var声明变量前,先打印变量,会打印出undefined,因为var声明的变量有变量提升,会在一开始先声明变量,然后到"var song = '日不落';"时开始赋值,故不会报错。

console.log(song);
var song = '日不落';

在这里插入图片描述

4.不影响作用域链

在块级作用域找不到变量时,回去全局作用域中寻找,let声明的变量不影响作用域链

let myAge = 18;
{console.log(myAge );
}

在这里插入图片描述

5.let的经典实例

目的:点击div,div变粉色,如图:
在这里插入图片描述

<!DOCTYPE html>
<html><head><meta charset="UTF-8"><title></title><style>.cantainer {display: flex;}.item {margin: 10px;width: 100px;height: 60px;border: solid black 1px;}</style><script type="text/javascript">window.onload = function() {// 获取div元素对象let items = document.getElementsByClassName('item');//遍历并绑定事件for(var i = 0; i < items.length; i++) {items[i].onclick = function() {//this.style.background = 'pink';//可以使用//不能使用,因为 var 声明的变量没有块级作用域的说法,后面 i 会变成 3,但是没有下标为 3的元素,故报错。items[i].style.background = 'pink';}}}</script></head><body><div class='cantainer'><div class='item'></div><div class='item'></div><div class='item'></div></div></body></html>

在这里插入图片描述
这里使用var声明变量i,因为没有块级作用域,所以i会变成3,但是没有下标为3的元素,所以报错。但是使用let声明变量i,因为有块级作用域,则不会报错,并且能成功运行。

const

1.const用来声明常量(值不能修改的量称为常量)

const SCHOOL = '河池学院';
console.log(SCHOOL); // 常量一般使用大写(潜规则)

2.常量必须赋初始值

const A;

在这里插入图片描述

3.常量的值不能修改

const SCHOOL = '河池学院';
SCHOOL = 'hcuniversity';
console.log(SCHOOL); // 常量一般使用大写(潜规则)

在这里插入图片描述

4.块级作用域

{const PLAYER = 'UZI';
}
console.log(PLAYER); // 常量一般使用大写(潜规则)

在这里插入图片描述

5.对于数组和对象的元素修改,不算做对常量的修改,不会报错

const ARRAY = ['A','B','C','D'];
ARRAY.push('E');
console.log(ARRAY); 

在这里插入图片描述因为没有改变常量地址的引用,所以不算修改,对象也是。

解构赋值

ES6允许按照一定模式从数组和对象中提取值,对变量进行赋值,这被称为解构赋值。

  1. 数组的解构
const F4 =['小沈阳','刘能','赵四','宋小宝'];
let [xiao, liu, zhao, song]= F4; // 将F4数组的值赋值给[xiao, liu, zhao, song]
console.log(xiao);
console.log(liu);
console.log(zhao);
console.log(song);

在这里插入图片描述

  1. 对象的解构
const player = {name: 'UZI',gender: '男',operate: function() {console.log('我要拿五杀!');}
}
let {name, gender, operate, age} = player; // 将对象player中的值依次赋给{name, gender, operate, age}
console.log(name);
console.log(gender);
console.log(operate);
console.log(age);  // 因为player中只有三个值,故age的值为undefined
operate(); // 直接调用方法,不需要用player.operate()的方式来调用,可以省略player

在这里插入图片描述

模板字符串(反引号)

1.声明

let str = `我也是字符串!`;
console.log(str, typeof str);

在这里插入图片描述

2.可以直接使用换行符

let ul = `<ul><li>沈腾</li><li>玛丽</li><li>魏翔</li><li>艾伦</li></ul>`; // 单引号和双引号都不能这样赋值,反引号却可以。

3.变量拼接

let lovest ='沈腾';
let out =`${ lovest }是我心目中最搞笑的演员!!`;
console.log(out);

在这里插入图片描述

简化对象写法

let name = '孙悟空';
let age = 18;
let operate = function() {console.log('我会七十二变!');
}const person ={name, // 简化写法,相当于name:nameage,operate,say(){ // 简化写法,省略functionconsole.log('妖怪,哪里跑!');}
} 
console.log(person);

在这里插入图片描述

箭头函数

1.声明

let fun = (a, b) => { // 省略了function,加入了=>return a+b;
}
let result= fun(1,2);
console.log(result); // 3

2.this是静态的,this 始终指向函数声明时所在作用域下的 this的值

let fun1 = function() {console.log(this.name);
}
let fun2 = () => {console.log(this.name);
}
window.name = '孙悟空';
const myName = {name:'猪八戒'
}// 1. 直接调用
fun1();  // 指向 window
fun2();  // 指向 window
// 2. 使用call方法调用
fun1.call(myName);  // 用call改变指向对象,指向 myName
fun2.call(myName);  // 没有改变指向对象,还是指向 window

在这里插入图片描述

3.不能作为构造函数实例化对象

let Person = (name, age) => {
this.name = name;
this.age = age;
}
let me = new Person('孙悟空',18);
console.log(me);

在这里插入图片描述
报错:Person不是构造函数

4.不能使用arguments变量

let fun = function() {
console.log(arguments);
}
fun(1,2,3);

在这里插入图片描述

let fun1 = () => {
console.log(arguments);
}
fun1(1,2,3);

在这里插入图片描述

5.箭头函数的简写

  1. 有且只有一个参数时,可以省略()
let add = n => { // 省略小括号()return n+n;
}
console.log(add(10)); // 20
  1. 函数代码体只有一句话时,可以省略{},并且省略return,语句的执行结果会作为返回值返回
let pow = n =>  n*n; // 省略(),{}和return
console.log(add(10)); // 100

箭头函数适合与this无关的回调。如:定时器,数组的方法回调等
箭头函数不适合与this有关的回调。如:事件回调,对象的方法等

rest参数和拓展运算符

这里看到大神的一篇博文,是否详尽,推荐给大家
ES6学习之路3----rest参数与扩展运算符

Symbol类型

1.啥是Symbol类型

Symbol 是ES6 中一种基本数据类型。Symbol() 函数返回的是 Symbol 类型的值,该类型具有静态方法和静态属性

2.为啥要用Symbol类型

ES5 的对象属性名都是字符串,这容易造成属性名的冲突。

比如,你使用了一个他人提供的对象,但又想为这个对象添加新的方法,新方法的名字就有可能与现有方法产生冲突。

如果有一种机制,保证每个属性的名字都是独一无二的就好了,这样就从根本上防止属性名的冲突。这就是 ES6 引入Symbol类型的原因。

3.怎么用Symbol类型

更详细的在这

ECMAScript 6 入门

ES7

1.Array.prototype.includes

Includes 方法用来检测数组中是否包含某个元素,返回布尔类型值

const array = ['孙悟空', '猪八戒', '沙和尚', '唐三藏'];
console.log(array.includes('孙悟空')); // true
console.log(array.includes('白骨精')); // false

2.指数操作符

在 ES7 中引入指数运算符「**」,用来实现幂运算,功能与 Math.pow 结果相同

console.log(2 ** 10); // 1024
console.log(Math.pow(2, 10)); // 1024

ES8

1.async 函数

  1. async 函数的返回值为 promise 对象,
  2. promise 对象的结果由 async 函数执行的返回值决定
async function fun() {return 1;
}
let result = fun();
console.log(result);

在这里插入图片描述
结果为成功状态的promise对象

async function fun() {throw error // 抛出错误
}
let result = fun();
console.log(result);

在这里插入图片描述
结果为失败状态的promise对象

2.await 表达式

  1. await 必须写在 async 函数中
  2. await 右侧的表达式一般为 promise 对象
  3. await 返回的是 promise 成功的值
  4. await 的 promise 失败了, 就会抛出异常, 需要通过 try…catch 捕获处理
async function fun() {try {let success= await Promise.resolve('我成功了');console.log(success);// await Promise.reject('我失败了');} catch(error) {console.log(error)}
}
fun();

3.Object.values 、Object.entries 和 Object.getOwnPropertyDescriptors

  1. Object.values()方法返回一个给定对象的所有可枚举属性值的数组
  2. Object.entries()方法返回一个给定对象自身可遍历属性 [key,value] 的数组
const book = {name:'西游记',person:['孙悟空', '猪八戒','沙和尚', '唐三藏'],event:['三打白骨精', '智取芭蕉扇', '大闹天宫']
}
// 获取对象所有的键
console.log(Object.keys(book));
// 获取对象所有的值
console.log(Object.values(book));
// 获取对象所有的键值对
console.log(Object.entries(book));
// 获取有属性描述的对象
console.log(Object.getOwnPropertyDescriptors(book));

在这里插入图片描述

ES9

1.Rest/Spread 属性

Rest 参数与 spread 扩展运算符在 ES6 中已经引入,不过 ES6 中只针对于数组,
在 ES9 中为对象提供了像数组一样的 rest 参数和扩展运算符

function connect({host, port, ...user}) {console.log(host);console.log(port);console.log(user);
}
connect({host: '127.0.0.1',port: 3306,username: 'root',password: 'root',type: 'master'
});

2.正则表达式命名捕获组

ES9 允许命名捕获组使用符号『?』,这样获取捕获结果可读性更强

let str = '<a href="http://www.baidu.com">百度</a>';
const reg = /<a href="(?<url>.*)">(?<text>.*)<\/a>/;
const result = reg.exec(str);
console.log(result.groups.url); // http://www.baidu.com
console.log(result.groups.text); // 百度

3.正则表达式 dotAll 模式

正则表达式中点.匹配除回车外的任何单字符,标记『s』改变这种行为,允许行
终止符出现

let str = `
<ul><li><a>肖生克的救赎</a><p>上映日期: 1994-09-10</p></li><li><a>阿甘正传</a><p>上映日期: 1994-07-06</p></li>
</ul>`;
//声明正则
const reg = /<li>.*?<a>(.*?)<\/a>.*?<p>(.*?)<\/p>/gs;
//执行匹配
let data = [];
while(result = reg.exec(str)){data.push({title: result[1], time: result[2]});
}
//输出结果
console.log(data);

在这里插入图片描述

ES10

Object.fromEntries 和 Object.entries

Object.fromEntries将二维数组转换为对象

const result = Object.fromEntries([['name', '孙悟空'],['event', '大闹天宫']
])
console.log(result);

在这里插入图片描述

Object.entries将对象转为二维数组

const result1 = Object.entries({name:'孙悟空'
})
console.log(result1);

在这里插入图片描述

trimStart 和 trimEnd

const str = '   123   ';
console.log(str);
console.log(str.trim()); // 去除左右两边的空格
console.log(str.trimStart()); // 去除左边的空格
console.log(str.trimEnd()); // 去除右边的空格

Array.prototype.flat 与 flatMap

const arr = [1,2,3,[4,5,[6,7,8]]];
let result1 = arr.flat(); // 将三维数组解析为二维数组
let result2 = arr.flat(2); // 将三维数组解析为一维数组,参数:解析的深度。不写时默认为1
console.log(result1);
console.log(result2);

在这里插入图片描述

const arr = [1, 2, 3, 4];
const result1 = arr.map(item => [item * 10]);
const result2 = arr.flatMap(item => [item * 10]);
console.log(result1);
console.log(result2);

在这里插入图片描述

ES11

类的私有属性

class Person{name;#age;#weight;constructor(name, age, weight){this.name = name;this.#age = age;this.#weight = weight;}intro() {console.log(this.name);console.log(this.#age);}
}
let p = new Person('孙悟空', 18, 99);
console.log(p.name);
p.intro(); // 但是可以在函数内部调用私有属性
console.log(p.#age); // 私有属性不能在外部调用,会报错

在这里插入图片描述

Promise.allSettled 和 Promise.all

Promise.allSettled 返回的永远是成功的promise对象
Promise.all ,传入的promise对象的状态都是成功时,返回成功的promise对象,否则就返回失败的promise对象

let p1 = new Promise((resolve, reject) => {resolve('成功111');
})
let p2 = new Promise((resolve, reject) => {reject('失败222');
})
const result = Promise.allSettled([p1, p2]);
const result1 = Promise.all([p1, p2]);
console.log(result);
console.log(result1);

在这里插入图片描述

这篇关于前端学习之 ES6-ES11的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学