Spread Syntax vs Rest Parameter in ES2015 / ES6

前端 未结 10 1659
隐瞒了意图╮
隐瞒了意图╮ 2020-11-27 10:52

I am confused about the spread syntax and rest parameter in ES2015. Can anybody explain the difference between them with proper examples?

相关标签:
10条回答
  • 2020-11-27 11:06

    Javascript's three dots ( ... ) operator can be used in two different ways:

    1. Rest parameter: collects all remaining elements into an array.

    var days = ["Sat", "Sun", "Mon", "Tue", "Wed", "Thu", "Fri"];
    const [sat, sun, ...weekdays] = days;
    console.log(sat); // "Sat"
    console.log(sun); // "Sun"
    console.log(weekdays); // ["Mon", "Tue", "Wed", "Thu", "Fri"]

    1. Spread operator: allows iterables( arrays / objects / strings ) to be expanded into single arguments/elements.

    var weekdays = ["Mon", "Tue", "Wed", "Thu", "Fri"];
    var days = [...weekdays, "Sat", "Sun"]; 
    console.log(days) // ["Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"]

    Note that the spread operator can be the first element, but the rest parameter needs to be the last to collect the rest elements .

    0 讨论(0)
  • 2020-11-27 11:08

    In reference to this i cant understand how we are passing a function and returning arguments in javascript

    Function is a set of instructions that takes some input and processes them and returns result.

    here we have an array [1, 2, 3, 4, 5, 6], and filter function iterates over each element and passes each element to positive functions which returns the number if it is even, else skips it.

    trace:

    1 => Filter(1) => positive(1) => skips 1,
    2 => Filter(2) => positive(2) => returns 2,
    3 => Filter(3) => positive(3) => skips 3,
    ...
    6 => Filter(6) => positive(6) => returns 6
    

    hence the result [2, 4, 6]

    0 讨论(0)
  • 2020-11-27 11:11

    considering 3 scenarios

    1] without using any operator

    function add(x, y) {
      return x + y;
    }
    
    add(1, 2, 3, 4, 5) // returns 3  (function will takes first 2 arg only)
    

    2] with rest operator

    function add(...args) {
      let result = 0;
    
      for (let arg of args) result += arg;
    
      return result
    }
    
    add(1) // returns 1
    add(1,2) // returns 3
    add(1, 2, 3, 4, 5) // returns 15
    

    - we can gather any number of arguments into an array

    3] with spread operator

    const arr = ["Joy", "Wangari", "Warugu"];
    const newArr = ["joykare", ...arr];
    
    The value of newArr will be [ 'joykare', 'Joy', 'Wangari', 'Warugu' ]
    

    another one

    function add(a, b, c) {
      return a + b + c ;
    }
    const args = [1, 2, 3];
    
    add(...args);
    
    -We have been using arrays to demonstrate the spread operator, 
    but any iterable also works. So, if we had a 
    string const str = 'joykare', [...str] translates to [ 'j', 'o', 'y', 'k', 'a', 'r', 'e' ]
    
    0 讨论(0)
  • 2020-11-27 11:12

    From: Ved Antani, Stoyan Stefanov Book “Object-Oriented JavaScript - Third Edition.” :

    Rest parameters

    ES6 introduces rest parameters. Rest parameters allow us to send an arbitrary number of parameters to a function in the form of an array. Rest parameter can only be the last one in the list of parameters, and there can only be one rest parameter. Putting a rest operator(...) before the last formal parameter indicates that parameter is a rest parameter. The following example shows adding a rest operator before the last formal parameter:

    function sayThings(tone, ...quotes){ 
      console.log(Array.isArray(quotes)); //true 
      console.log(`In ${tone} voice, I say ${quotes}`) 
    } 
    sayThings("Morgan Freeman","Something serious"," 
     Imploding Universe"," Amen"); 
    //In Morgan Freeman voice, I say Something serious,
     Imploding Universe,Amen 
    

    The first parameter passed to the function is received in tone, while the rest of the parameters are received as an array. Variable arguments (var-args) have been part of several other languages and a welcome edition to ES6. Rest parameters can replace the slightly controversial arguments variable. The major difference between rest parameters and the arguments variable is that the rest parameters are real arrays. All array methods are available to rest parameters.

    Spread operators

    A spread operator looks exactly like a rest operator but performs the exact opposite function. Spread operators are used while providing arguments while calling a function or defining an array. The spread operator takes an array and splits its element into individual variables. The following example illustrates how the spread operator provides a much clearer syntax while calling functions that take an array as an argument:

    function sumAll(a,b,c){ 
      return a+b+c 
    } 
    var numbers = [6,7,8] 
    //ES5 way of passing array as an argument of a function 
    console.log(sumAll.apply(null,numbers)); //21 
    //ES6 Spread operator 
    console.log(sumAll(...numbers))//21 
    
    0 讨论(0)
  • 2020-11-27 11:13

    Added in ES6 these three dots ... has two meanings, Spread operator and Rest parameter

    Spread operator: You use the three dots to expand iterables, by iterables I mean arrays, string, etc. As arguments. For example Math.max() function expect an indeterminate number of arguments so you can use Spread operator to expand elements as arguments on Math.max() function. Here an example from mdn

    console.log(Math.max(1, 3, 2));
    // expected output: 3
    
    console.log(Math.max(-1, -3, -2));
    // expected output: -1
    
    var array1 = [1, 3, 2];
    
    console.log(Math.max(...array1));
    // expected output: 3
    

    Another use case is to add, for example having this array

    const videoGames = ['mario galaxy', 'zelda wind waker', 'ico'];
    

    You can add it to another array

    const favoritesVideoGames = ['Shadow of the colosus', ...videoGames];
    

    Then favoritesVideoGames value is

    [ 'Shadow of the colosus', 'mario galaxy', 'zelda wind waker', 'ico' ]
    

    About Rest parameter, here the MDN definition

    The rest parameter syntax allows us to represent an indefinite number of arguments as an array.

    This means you can pack many elements into a single element

    Here an example from MDN

    function sum(...theArgs) {
      return theArgs.reduce((previous, current) => {
        return previous + current;
      });
    }
    
    console.log(sum(1, 2, 3));
    // expected output: 6
    
    console.log(sum(1, 2, 3, 4));
    // expected output: 10
    

    I usually get confused with these three points, this illustration by @stephaniecodes helps me to remember its logic. I mention that I took inspiration from this illustration to answer this question.

    I hope it is useful.

    0 讨论(0)
  • 2020-11-27 11:19

    When using spread, you are expanding a single variable into more:

    var abc = ['a', 'b', 'c'];
    var def = ['d', 'e', 'f'];
    var alpha = [ ...abc, ...def ];
    console.log(alpha)// alpha == ['a', 'b', 'c', 'd', 'e', 'f'];

    When using rest arguments, you are collapsing all remaining arguments of a function into one array:

    function sum( first, ...others ) {
        for ( var i = 0; i < others.length; i++ )
            first += others[i];
        return first;
    }
    console.log(sum(1,2,3,4))// sum(1, 2, 3, 4) == 10;

    0 讨论(0)
提交回复
热议问题