zoukankan      html  css  js  c++  java
  • What do these three dots in React do?

    What do these three dots in React do?

    回答1

    That's property spread notation. It was added in ES2018 (spread for arrays/iterables was earlier, ES2015), but it's been supported in React projects for a long time via transpilation (as "JSX spread attributes" even though you could do it elsewhere, too, not just attributes).

    {...this.props} spreads out the "own" enumerable properties in props as discrete properties on the Modal element you're creating. For instance, if this.props contained a: 1 and b: 2, then

    <Modal {...this.props} title='Modal heading' animation={false}>
    

    would be the same as

    <Modal a={this.props.a} b={this.props.b} title='Modal heading' animation={false}>
    

    But it's dynamic, so whatever "own" properties are in props are included.

    Since children is an "own" property in props, spread will include it. So if the component where this appears had child elements, they'll be passed on to Modal. Putting child elements between the opening tag and closing tags is just syntactic sugar — the good kind — for putting a children property in the opening tag. Example:

    Spread notation is handy not only for that use case, but for creating a new object with most (or all) of the properties of an existing object — which comes up a lot when you're updating state, since you can't modify state directly:

    this.setState(prevState => {
        return {foo: {...prevState.foo, a: "updated"}};
    });
    

    That replaces this.state.foo with a new object with all the same properties as foo except the a property, which becomes "updated":

    const obj = {
      foo: {
        a: 1,
        b: 2,
        c: 3
      }
    };
    console.log("original", obj.foo);
    // Creates a NEW object and assigns it to `obj.foo`
    obj.foo = {...obj.foo, a: "updated"};
    console.log("updated", obj.foo);
    .as-console-wrapper {
      max-height: 100% !important;
    }

    回答2

    375
     

    As you know ... are called Spread Attributes which the name represents it allows an expression to be expanded.

    var parts = ['two', 'three'];
    var numbers = ['one', ...parts, 'four', 'five']; // ["one", "two", "three", "four", "five"]
    

    And in this case(I'm gonna simplify it).

    //just assume we have an object like this:
    var person= {
        name: 'Alex',
        age: 35 
    }
    

    This:

    <Modal {...person} title='Modal heading' animation={false} />
    

    is equal to

    <Modal name={person.name} age={person.age} title='Modal heading' animation={false} />
    

    So in short, it's a neat short-cut, we can say.

    回答3

    The three dots represent the Spread Operator in ES6. It allows us to do quite a few things in Javascript:

    1. Concatenate arrays

      var shooterGames = ['Call of Duty', 'Far Cry', 'Resident Evil'];
      var racingGames = ['Need For Speed', 'Gran Turismo', 'Burnout'];
      var games = [...shooterGames, ...racingGames];
      
      console.log(games)  // ['Call of Duty', 'Far Cry', 'Resident Evil',  'Need For Speed', 'Gran Turismo', 'Burnout']
      
    2. Destructuring an array

        var shooterGames = ['Call of Duty', 'Far Cry', 'Resident Evil'];
        var [first, ...remaining] = shooterGames;
        console.log(first); //Call of Duty
        console.log(remaining); //['Far Cry', 'Resident Evil']
      
    3. Combining two objects

      var myCrush = {
        firstname: 'Selena',
        middlename: 'Marie'
      };
      
      var lastname = 'my last name';
      
      var myWife = {
        ...myCrush,
        lastname
      }
      
      console.log(myWife); // {firstname: 'Selena',
                           //   middlename: 'Marie',
                           //   lastname: 'my last name'}
      

    There's another use for the three dots which is known as Rest Parameters and it makes it possible to take all of the arguments to a function in as one array.

    1. Function arguments as array

       function fun1(...params) { 
      
       }  
      
  • 相关阅读:
    实验教学管理系统 c语言程序代写源码下载
    模拟游客一天的生活与旅游java程序代写源码
    Java作业代写
    快餐店运行模拟C++程序源码代写
    HTML+CSS实例——漂亮的背景(一)
    HTML+CSS实例——漂亮的查询部件(一)
    求可能组合VB源码代写
    专业程序代写
    (重刷)HDU 1874 畅通工程续 + HDU 2544 最短路 最短路水题,dijkstra解法。
    价值链与项目组模式打通专业管理模式的竖井
  • 原文地址:https://www.cnblogs.com/chucklu/p/14177976.html
Copyright © 2011-2022 走看看