2022-09-20 ES语法新特性

ES语法新特性

  1. let
// 声明变量
let a;
let b, c, d;
// 1. 变量不能重复声明
// 2. 块儿级作用域  全局,函数,eval
// 3.不存在变量提升(在未声明前使用变量  )
// 4.不影响作用域链
  1. const
const
// 1. 一定要赋初始值
const A
// 2. 一般常量使用大写(潜规则)
const a =100
// 3. 常量的值不能修改 
// 4. 块儿作用域
// 5. 对于数组和对象的元素修改, 不算做对常量的修改, 不会报错
  1. 变量的解构赋值
1. 数组的解构
const F4=['小沈阳', '刘能','赵四','宋小宝']
let [xiao, liu, zhao, song] = F4
2. 对象的解构
const zhao = {
name: '赵本山',
age: '不详',
xiaopin: function (){
consloe.log('666')
  }
};

let  {name, age, xiaopin} = zhao 
  1. 模板字符串
新的声明字符串的方式 ``   ''   ""
1. 声明
2. 内容中可以直接出现换行符 [ `` ]
3. 拼接变量
let lovest ='lol'
let out = `${lovest}老好了` 
  1. 简化对象写法
ES6 允许在{}里直接写入变量和函数,作为对象的属性和方法
  1. 箭头函数
let ok = () =>{}

// 1. this是静态的, this 始终指向函数声明是所在作用域下的this 的值
// 2. 不能作为构造实例化对象
// 3. 不能使用arguments 变量

  1. 函数参数默认值
    ES6 允许给函数参数赋值初始值
// 1. 形参初始值  具有默认值的参数,一般靠后
function add(a, b, c=10) {
return a+ b + c
}
let result = add(1, 2)
result = 13
// 2. 与解构赋值结合
  1. rest 参数
function data(...args){
console.log(args);
}
date('12','23','34')
// rest 参数必须放到参数最后
  1. 扩展运算符
    ... 扩展运算符能将 数组 转换为逗号分割的 序列参数
// 1. 数组的合并
const kuaizi = ['王','刘']
const mengnan = ['俊', '鑫']
// ES5
const daMengNan = kuaizi.concat(mengnan)
// ES6
const daMengNan = [...kuaizi, ...mengnan ]
// 2. 数组克隆
const kuaizi = ['王','刘']
const mengnan = [...kuaizi]
//3. 将伪数组转为真正的数组
const  divs = document.querySelectorAll('div')
const divArr = [...divs]
  1. symbol
// 创建symbol 
let s = symbol();
let s1 = symbol('猛男');
let s2 = symbol('猛男')
log (s1 === s2)  >>>>false  ,   symbol是一个标志
// symbol.for 创建
let s3 = symbol.for('猛男');
let s4 = symbol.for('猛男');
log (s3 === s4)  >>>>true
// 不能与其他数据进行运算
  1. promise 读取文件
// 1. 引入 fs 模块
const fs = require('fs')
// 2. 调用方法读取文件
fs.readFile('./resources/xx.md', (err,data) =>{
      // 如果错误 , 抛出错误
      if(err) throw err;
      // 如果没错, 输出内容
      console.log(data.toString());
});
// 3. 使用Promise 封装
const P = new Promise(function(resolve, reject)){
    fs.readFile('./resources/xx.md', (err,data) =>{
      // 如果错误 
      if(err) reject(err);
      // 如果成功
      resolve(data);
  });
});
p.then(function(value){
    console.log(value.toString());
}, function(reason){
    console.log('读取失败');  
})

  1. set
let arr  = [1,2,1,1,3,4,]
// 1.数组去重
let result = [...new Set(arr)]
// 2. 交集
let arr2 = [2,3]
let result =  [...new Set(arr)].filter (item => {
   let s2 = new Set(arr2);
   if (s2.has(item)){
      return true;
  }else {
      return false
   }
});
let result =  [...new Set(arr)].filter(item => new Set(arr2).has(item) )

// 3. 并集 
let result =  [...new Set([...arr,...arr2]) ]
// 4. 差集
let diff = [...new Set(arr)].filter(item => !(new Set(arr2).has(item)))
  1. map
// 声明 map
let m = new Map();
// 添加元素
m.set('name','酷毙');
m.set('change', function(){
  console.log('我们可以改变你')
});
let key = {
  school: '帅呆' 
};
m.set(key, ['北京','上海','深圳']) 
// size
console.log(m.size)
// 删除
m.delate()
// 清空
m.clear()
// 遍历
for (let v of m ){
   console.log(v)
}
  1. 数值扩展
// 检测一个数值是否为有限数
Number.isFinite  
// 检测一个数是否为NaN
Number.isNaN
// 字符串转数字
Number.parseInt
Number.parseFloat
// 是否为整数
Number.isInteger
// 将数字小数部分抹掉
Math.trunc
//判断到底是正数 负数 还是零
Math.sign
  1. 对象方法扩展
// 1. object.is 判断两个值是否完全相等
// 2. object.assign 对象的合并
object.assign(config1,config2) // 后面参数属性将前面覆盖
// 3. object.setPrototypeOf 设置原型对象
  1. 暴露语法
// 1. 分别暴露
export let school = 'school'
export function teach (){}
// 2. 统一暴露
 let school = 'school'
 function teach (){}
export {school, teach}
// 3. 默认暴露
export default{
  school:'school'
  change: function(){
  console.log('awesome')
  }
}

引用语法

// 1. 通用导入
import * as m1 from './xxx'
// 2. 解构赋值形式
import {school, teach} from 'xxxx'
import {school as xuexiao, teach} from 'xxxx'    // 重名可以用 as 起别名
import { default as m3}  from 'xxxx '
// 3. 简便形式 针对默认暴露
import m3 from 'xxxx'
  1. includes
// includes  indexOf
const  mingzhu = ['西游记','水浒传', '三国演义', '红楼梦']
// 判断 
console.log(mingzhu.includes('西游记'))
====>> true
  1. Object.fromEntries()
// 通过 Object.fromEntries, 可以将 Map 转化为 Object:
const map = new Map([ ['foo', 'bar'], ['baz', 42] ]);
const obj = Object.fromEntries(map);
console.log(obj); // { foo: "bar", baz: 42 }
// 通过 Object.fromEntries, 可以将 Array 转化为 Object:
const arr = [ ['0', 'a'], ['1', 'b'], ['2', 'c'] ];
const obj = Object.fromEntries(arr);
console.log(obj); // { 0: "a", 1: "b", 2: "c" }

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 229,237评论 6 537
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 98,957评论 3 423
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 177,248评论 0 382
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 63,356评论 1 316
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 72,081评论 6 410
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 55,485评论 1 324
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 43,534评论 3 444
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 42,720评论 0 289
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 49,263评论 1 335
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 41,025评论 3 356
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 43,204评论 1 371
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 38,787评论 5 362
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,461评论 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 34,874评论 0 28
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 36,105评论 1 289
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 51,945评论 3 395
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 48,205评论 2 375

推荐阅读更多精彩内容