由于填充,Flexbox无法居中文本

Lou*_*345 5 html css flexbox reactjs

我正在尝试创建一个flexbox网格,当内容超出宽度时,它会换行.我正在使用flexbox wrap来实现这一目标.问题是内容未正确对齐,因为所有单词都不包含相同数量的字符.

我试图实现这个设计乍一看似乎很简单:

我最好的尝试是这样的:

我的代码是:

.bg {
  width: 990px;
  padding: 124px;
  height: auto;
  border-radius: 6px;
  background-color: #fff;
  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.5);
}

.flexgrid {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  word-wrap: break-word;
}

.wrap {
  display: flex;
  flex-direction: column;
  text-align: center;
  border-top: 1px solid black;
  padding: 33px;
  flex: 1;
  flex-basis: auto;
}

return (
      <div className={classes.container}>
        <div className={classes.bg}>
          <h1>My Flashcards</h1>
          <br />
          <div className={classes.flashcardcontainer}>
            <div className={classes.flexgrid}>
              {decks.map((deck, index) => {
                return (
                  <FlashcardDeck
                    label={deck.label}
                    lastItem={decks.length === index + 1}
                    key={index}
                  />
                );
              })}
            </div>
          </div>
        </div>
      </div>
    );
  }
}

const flashCardDeck = props => {
  return (
    <div className={classes.wrap}>
      <img src={deckImage} />
      <p>{props.label}</p>
    </div>
  );
};
Run Code Online (Sandbox Code Playgroud)

Anz*_*haN 1

flex-basis将.wrap 选择器的值更改为flex-basis: 25%

.wrap {
  display: flex;
  flex-direction: column;
  text-align: center;
  border-top: 1px solid black;
  padding: 33px;
  flex: 1;
  flex-basis: 25%;
}
Run Code Online (Sandbox Code Playgroud)