普歌-码上鸿鹄团队复习: js高级 ES6 [上]

ECMASript 6 新特性(ES6)

1.1 let关键字

let 关键字用来声明变量,使用 let 声明的变量有几个特点:

  1. 不允许重复声明
//错误写法 不允许重复声明
let test = "gl";
let test = "star";
  1. 块儿级作用域
   //块级作用域  if else  while for都属于块级作用域
   {
   let test = "测试";
   }
   consle.log(test);  //这条语句会报错
   //注:在块级作用域内定义的let变量,在块级作用域之外是不允许使用;var可以使用
  1. 不存在变量提升
  //var 存在变量提升
   consle.log(sing);   //控制台打印出"唱歌"的字样
   var sing = "唱歌";

   //let 不存在变量提升
   consle.log(sing);   //控制台报错,如下图
   let sing = "唱歌";
在这里插入图片描述
  1. 不影响作用域链
   //let不会影响作用域链
    {
    let name = "张三";
      function fn(){
        consle.log(name);   //去上一级作用域找name变量
      }
      fn();  //控制台正常输出"张三"
    }

1.2 const 关键字

const 关键字用来声明常量(值不能被修改的叫常量), const 声明有以下特点

  1. 声明必须赋初始值
const TEST;  //错误写法,必须赋初始值
const TEST = 5;  //正确写法
  1. 标识符一般为大写(潜规则)
 //标识符一般大写,代码规范
 const A = 100;
 //小写也没有错
 const a = 100;
  1. 不允许重复声明
//错误写法 不允许重复声明
const TEST= "gl";
const TEST= "star";
  1. 值不允许修改
//错误写法 不允许修改值
const TEST= "gl";
TEST= "star"; //报错
  1. 块儿级作用域
   //块级作用域  if else  while for都属于块级作用域
   {
   const TEST= 100;
   }
   consle.log(TEST);  //这条语句会报错
   //注:在块级作用域内定义的const常量,在块级作用域之外是不允许使用;var可以使用

<font color="red" size=4>注意: 对象属性修改和数组元素变化不会出发 const 错误
应用场景:声明对象类型使用 const,非对象类型声明选择 let</font>

1.3 let const var 的区别

在这里插入图片描述

1.4 变量的解构赋值

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

//数组的解构赋值
 const arr = ['张学友', '刘德华', '黎明', '郭富城'];
 let [zhang, liu, li, guo] = arr;
consle.log(zhang);  //控制台打印"张学友"
consle.log(liu);  //控制台打印"刘德华"
consle.log(li);  //控制台打印"黎明"
consle.log(guo);  //控制台打印"郭富城"
//-------------------------------------------------------------


//对象的解构赋值
const lin = {
    name: '林志颖',
    tags: ['车手', '歌手', '小旋风', '演员'],
    car:function(){
       consle.log("我是车手");
    }
};
 let {name, tags, car} = lin;
consle.log(name); //控制台打印"林志颖"
consle.log(tags); //控制台打印['车手', '歌手', '小旋风', '演员']这个数组
car();  //控制台打印"我是车手"


//复杂解构
let wangfei = {
    name: '王菲',
    age: 18,
    songs: ['红豆', '流年', '暧昧', '传奇'],
    history: [
       {name: '窦唯'},
       {name: '李亚鹏'},
       {name: '谢霆锋'}
    ]
};
let {songs: [one, two, three], history: [first, second, third]} =
wangfei;

注意:频繁使用对象方法、数组元素,就可以使用解构赋值形式

1.5 模板字符串

模板字符串(template string)是增强版的字符串, 用反引号(`)标识,特点:

  1. 字符串中可以出现换行符
  2. 可以使用 ${xxx} 形式输出变量
// 定义字符串,可以出现换行
let str = `<ul>
           <li>大傻</li>
           <li>二傻</li>
           <li>三傻</li>
           <li>四傻</li>
         </ul>`;
// 变量拼接
let star = '我';
let result = `${star}不是傻子`; //result的值是字符串变量"我不是傻子"

注意:当遇到字符串与变量拼接的情况使用模板字符串

1.6 简化对象写法

ES6 允许在大括号里面,直接写入变量和函数,作为对象的属性和方法。这
样的书写更加简洁。

let name = '小高';
let skills= '我会前端开发';
let improve = function () {
   console.log('努力提高自己');
}
//属性和方法简写
let obj= {
  name,   //相当于name:name,输出小高
  skills,  //相当于skills:skills,输出我会前端开发
  improve,  
  change() {
     console.log('你一定可以蜕变')
   }
};

<font color="red">注意:对象简写形式简化了代码,所以以后用简写就对了</font>

1.7 箭头函数

ES6 允许使用「箭头」 (=>)定义函数。

/**
* 1. 通用写法
*/
let fn = (arg1, arg2, arg3) => {
    return arg1 + arg2 + arg3;
}

箭头函数的注意点:

  1. 如果形参只有一个,则小括号可以省略
  2. 函数体如果只有一条语句,则花括号可以省略,函数的返回值为该条语句的
    执行结果
  3. <font color="red"> 箭头函数 this 指向声明时所在作用域下 this 的值</font >
  4. 箭头函数不能作为构造函数实例化


    在这里插入图片描述
  5. 不能使用 arguments


    在这里插入图片描述
  6. 下面是箭头函数简写的几种情况
/**
* 2. 省略小括号的情况,当形参只有一个的时候
*/
let fn2 = num => {
   return num * 10;
};
/**
* 3. 省略花括号的情况,
* 当代码体只有一条语句,而且语句的执行结果就是函数的返回值
*/
let fn3 = score => score * 20;
/**
* 4. this 指向声明时所在作用域中 this 的值
*/
let fn4 = () => {
   console.log(this);
}
let school = {
     name: '小高',
   getName(){
     let fn5 = () => {
        console.log(this);
     }
    fn5();
  }
};

注意:箭头函数不会更改 this 指向,用来指定回调函数会非常合适

1.8 rest 参数(剩余参数)

ES6 引入 rest 参数,用于获取函数的实参,用来代替 arguments

 /**
  rest参数
* 作用与 arguments 类似
*/
function add(...args){
   console.log(args);
}
add(1,2,3,4,5);  //args打印出来是一个数组
/**
* rest 参数必须是最后一个形参
*/
function minus(a,b,...args){
console.log(a,b,args);
}
minus(100,1,2,3,4,5,19); 
//args里的值:[2,3,4,5,19]
在这里插入图片描述

<font color="red">注意: rest 参数非常适合不定个数参数函数的场景</font>

1.9 spread 扩展运算符(...)

扩展运算符(spread)也是三个点(...)。它好比 rest 参数的逆运算,将一
个数组转为用逗号分隔的参数序列,对数组进行解包。

/**
* 展开数组
*/
let tfboys = ['德玛西亚之力','德玛西亚之翼','德玛西亚皇子'];
function fn(){
console.log(arguments);
}
fn(...tfboys);
/**
* 展开对象
*/
let skillOne = {
  q: '致命打击',
};
let skillTwo = {
  w: '勇气'
};
let skillThree = {
  e: '审判'
};
let skillFour = {
  r: '德玛西亚正义'
};
let gailun = {...skillOne, ...skillTwo,...skillThree,...skillFour}; 
/*
*数组的合并
*/

const one = ["一","二"];
const two = ["三","四"];
const hebin = [...one,...two];
consle.log(hebin ); //=>相当于["一","二","三","四"]
/*
*数组的克隆
*/

const one = ["一","二"];
const kelong = [...one];
consle.log(kelong);//=>相当于["一","二"]
在这里插入图片描述

1.10 Symbol

1.10.1 Symbol 基本使用

ES6 引入了一种新的原始数据类型 Symbol,表示独一无二的值。它是
JavaScript 语言的第七种数据类型,是一种类似于字符串的数据类型。
Symbol 特点

  1. Symbol 的值是唯一的,用来解决命名冲突的问题
  2. Symbol 值不能与其他数据进行运算
  3. Symbol 定义 的 对象属 性 不能 使 用 for…in 循 环遍 历 ,但 是可 以 使 用Reflect.ownKeys 来获取对象的所有键名
//创建 Symbol
let s1 = Symbol();
console.log(s1, typeof s1);  //打印输出  Symbol  "symbol"
//添加标识的 Symbol
let s2 = Symbol('高');
let s2_2 = Symbol('高');
console.log(s2 === s2_2);  //false
//使用 Symbol for 定义
let s3 = Symbol.for('高官厚禄');
let s3_2 = Symbol.for('高官厚禄');
console.log(s3 === s3_2); //true

<font color="red">注: 遇到唯一性的场景时要想到 Symbol</font>

1.10.2 Symbol 内置值

除了定义自己使用的 Symbol 值以外, ES6 还提供了 11 个内置的 Symbol 值,指向语言内部使用的方法。 可以称这些方法为魔术方法,因为它们会在特定的场景下自动执行。

内置值 场景
Symbol.hasInstance 当其他对象使用 instanceof 运算符,判断是否为该对象的实例时,会调用这个方法
Symbol.isConcatSpreadable 对象的 Symbol.isConcatSpreadable 属性等于的是一个布尔值,表示该对象用于 Array.prototype.concat()时,是否可以展开。
Symbol.species 创建衍生对象时,会使用该属性
Symbol.match 当执行 str.match(myObject) 时,如果该属性存在,会调用它,返回该方法的返回值。
Symbol.replace 当该对象被 str.replace(myObject)方法调用时,会返回该方法的返回值。
Symbol.search 当该对象被 str. search (myObject)方法调用时,会返回该方法的返回值。
Symbol.split 当该对象被 str. split (myObject)方法调用时,会返回该方法的返回值。
Symbol.iterator 对象进行 for...of 循环时,会调用 Symbol.iterator 方法,返回该对象的默认遍历器
Symbol.toPrimitive 该对象被转为原始类型的值时,会调用这个方法,返回该对象对应的原始类型值。
Symbol. toStringTag 在该对象上面调用 toString 方法时,返回该方法的返回值
Symbol. unscopables 该对象指定了使用 with 关键字时,哪些属性会被 with环境排除。

<font size=4>相关推荐:wantLG的《普歌-码上鸿鹄团队复习总结:js 高级 ECMAScript 6(es6新特性)(下)》</font>


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