zoukankan      html  css  js  c++  java
  • ES7新特性

    ES6是多年来JavaScript的重大版本变革,深受开发者的欢迎。

    ES6就是ES2015,也就是从此时开始,JavaScript变为每年更新一次,按年计算依次类推。ES7(2016年)、ES8(2017年)、ES9(2018年)。

    除了ES6更新幅度较大之外,后面的几次更新较小。了解起来也比较容易。

    ES7

    ES7在ES6的基础上添加了三个内容:求幂运算符(**)、Array.prototype.includes()方法以及函数作用域中严格模式的变更。

    1、求幂运算符(**)

    console.log( 3**2 )  // 9
    // 相当于 数学方法 Math.pow(3, 2)

    使用起来更简洁。

    2、Array.prototype.includes() 方法

    此方法是判断一个元素是否在数组中,返回一个布尔值,true或者false。该方法只能判断一些简单类型的数据,复杂类型则无法判断。和indexOf方法作用类似。

    该方法接受两个参数,第一个就是要判断的数据,第二个是开始位置的索引值。

     1 let arr1 = [1, 2, 3, 'tom', 'jerry'];
     2 let arr2 = [1, [2, 3], 4];
     3 let arr3 = [{name: 'tom'}, {name: 'jerry'}, {age: 24}];
     4 
     5 console.log( arr1.includes(1) )             // true
     6 console.log( arr1.includes(1, 1) )             // false  从下标为1的开始
     7 console.log( arr1.includes('tom') )         // true
     8 console.log( arr2.includes([2, 3]) )        // false
     9 console.log( arr3.includes({name: 'tom'}) ) // false
    10 console.log( arr1.indexOf(1) )             // 0
    11 console.log( arr1.indexOf('tom') )         // 3
    12 console.log( arr2.indexOf([2, 3]) )        // -1
    13 console.log( arr3.indexOf({name: 'tom'}) ) // -1

    与indexOf的优劣:如果只是判断某元素是否存在于数组中,includes 方法更好些,因为是返回的布尔值可以直接拿来判断使用。

    如果想要判断是否存在于数组中并且想要获取该元素的下标,则 indexOf方法更好些。

    还有一点:就是对 NaN 的判断:

    1 let arr4 = [1, 2, NaN];
    2 console.log( arr4.indexOf(NaN) )    // -1
    3 console.log( arr4.includes(NaN) )   // true
  • 相关阅读:
    设计模式之单例模式实践
    有关集合的foreach循环里的add/remove
    项目中常用的MySQL优化方法--壹拾玖条
    Solr
    Lucene补充
    Lucene
    一千行 MySQL 学习笔记
    Servlet
    CSS未知宽高元素水平垂直居中
    深拷贝和浅拷贝
  • 原文地址:https://www.cnblogs.com/xguoz/p/11421219.html
Copyright © 2011-2022 走看看