Reaction-动态呈现一定数量的组件

React - Render a certain number of components dynamically(Reaction-动态呈现一定数量的组件)

本文介绍了Reaction-动态呈现一定数量的组件的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想根据用户获得的点数(this.state.points)显示星型组件(MUI组件)的数量。

我不知道怎么做。

import React, { Component } from "react";
import { Star } from "@material-ui/icons";

Points extends Component {
  constructor(props) {
  super(props);
    this.state = {
      points: 6
    };
  }

  render() {
     return (
       <div>
         <p>
           + {this.state.points} points
           <Star />
         </p>
       </div>
     );
    }
  }

export default Points;

推荐答案

您可以使用Array.fill创建具有this.state.points空槽数量的新数组,然后使用<Star />组件进行填充,如下所示:

import React, { Component } from "react";
import { Star } from "@material-ui/icons";

class Points extends Component {
  constructor(props) {
    super(props);
    this.state = {
      points: 6
    };
  }

  render() {
    return (
      <div>
        <p>
          + {this.state.points} points
          // This is where the magic happens
          {Array(this.state.points).fill(<Star />)}
        </p>
      </div>
    );
  }
}

export default Points;

这是一个工作沙盒:https://codesandbox.io/s/vj3xpyn0x0

这篇关于Reaction-动态呈现一定数量的组件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:Reaction-动态呈现一定数量的组件