zoukankan      html  css  js  c++  java
  • JavaScript 扩展运算符

    扩展运算符格式

    扩展运算符格式很简单,就是三个点(…)

    重点:需要ES6 语法支持

    扩展运算符作用:说简单一点就是进行位置扩展的。

    1、将一个数组放入另一个数组中

    下面开始通过四个例子来深刻理解扩展运算符

    1、创建一个数组middle 
    2、创建第二个包含middle的数组 
    3、输出结果

    var middle = [3, 4];
    var arr = [1, 2, middle, 5, 6];
    console.log(arr);
    // [1, 2, [3, 4], 5, 6]

    在上例中,没有使用扩展运算符。middle作为数组放入另一个数组中

    2、如果想让输出结果只有一个数组???

    这时候就用到扩展运算符,看下面例子,除了使用扩展运算符其他都与上面例子相同。

    var middle = [3, 4];
    var arr = [1, 2, ...middle, 5, 6];
    console.log(arr);
    // [1, 2, 3, 4, 5, 6]

    当创建数组arr和使用在middle数组上使用扩展运算符时,不是将middle数组直接插入到arr中,而是将middle数组扩展,然后将元素插入到arr中。

    3、复制数组

    slice()是JavaScript数组的方法,作用是复制数组。我们同样可以使用扩展运算符复制数组。

    var arr = ['a', 'b', 'c'];
    var arr2 = [...arr];
    console.log(arr2);
    // ['a', 'b', 'c']

    arr数组中的元素扩展成为单独元素被分配到arr2中。现在可以随意改变arr2数组,且都不会对源数组arr产生影响

    这是因为,arr数组值被扩展后添加到arr2数组中,我们设置arr2等于arr的值,而不是其本身。我们可以关注没有扩展运算符时发生事情,就能理解了。

    如果创建数组然后设置另一个数组等于其本身,如下:

    var arr = ['a', 'b', 'c'];
    var arr2 = arr;
    console.log(arr2);
    // ['a', 'b', 'c']

    现在我们将arr2数组赋值给arr数组,这意味着只要改变arr2,arr数组就会发生变化。

    arr2.push('d');
    console.log(arr2);
    // ['a', 'b', 'c', 'd']
    console.log(arr);
    // ['a', 'b', 'c', 'd']

    4、拼接数组

    使用扩展运算符可以代替concat()来拼接数组。

    var arr = ['a', 'b', 'c'];
    var arr2 = ['d', 'e', 'f'];
    
    arr1 = arr.concat(arr2);
    console.log(arr);
    // ['a', 'b', 'c', 'd', 'e', 'f']

    使用扩展运算符

    var arr = ['a', 'b', 'c'];
    var arr2 = ['d', 'e', 'f'];
    arr = [...arr, ...arr2];
    console.log(arr);
    // ['a', 'b', 'c', 'd', 'e', 'f']

    5、Math

    也可以使用math函数连同扩展运算符。如这个例子中,将使用Math.max()

    Math.max()将返回一组数最大值。

    Math.max();
    // -Infinity
    Math.max(1, 2, 3);
    // 3
    Math.max(100, 3, 4);
    // 100

    在没有扩展运算符,在数组上使用Math.max()最容易方法就是使用.apply()。

    var arr = [2, 4, 8, 6, 0];
    function max(arr) {
      return Math.max.apply(null, arr);
    }
    console.log(max(arr));
    // 8

    现在看看使用扩展运算符做同样事情。只需要两行代码就可以做到同样效果。

    var arr = [2, 4, 8, 6, 0];
    var max = Math.max(...arr);
    console.log(max);
    // 8

    6、字符串转数组

    使用扩展运算符将字符串转换为数组。
    var str = "hello";
    var chars = [...str];
    console.log(chars); 
    // ['h', 'e',' l',' l', 'o']
    联系作者: VX:Mm_Lewis
  • 相关阅读:
    css实现鼠标移入table时出现滚动条且table内容不移位
    SASS学习笔记
    html5--canvas学习笔记
    在iframe里调用parent.func()引出的js函数运行在它们被定义的作用域里,而不是它们被执行的作用域里
    css background-position:x% y%
    js十进制等互相转换
    jsp中的动作元素:<jsp:plugin>
    终于有时间写代码了
    OK 开始实践书上的项目一:即使标记
    我没有忘记敲代码
  • 原文地址:https://www.cnblogs.com/lewis-messi/p/8514186.html
Copyright © 2011-2022 走看看