0
votes

Comment étirer la colonne du milieu dans une configuration de grille à 3 colonnes

J'essaie de configurer un en-tête avec un système « grid » à une seule ligne et trois colonnes. Tels que:

<div class="wrapper">
  <div class="item1">Item 1</div>
  <div class="item2">Item 2</div>
  <div class="item3">Item 3</div>
</div>
* {box-sizing: border-box;}

.wrapper {
    border: 2px solid #f76707;
    border-radius: 5px;
    background-color: #fff4e6;
}

.wrapper > div {
    border: 2px solid #ffa94d;
    border-radius: 5px;
    background-color: #ffd8a8;
    padding: 1em;
    color: #d9480f;
}
.wrapper {
  display: grid;
  grid-template-columns: 100px,1fr,100px;
  grid-template-rows: 1fr;

  grid-template-areas: "a b c";

}
.item1 {
  grid-area: a;
  justify-self:start;
}
.item2 {
  grid-area: b;
  justify-self:stretch;
}
.item3 {
  grid-area: c;
  justify-self:end;
}

Cependant, la colonne du milieu ne fera que centrer plutôt que s'étirer. Voici le violon https://jsfiddle.net/mmo7534/pnxtys79/2/ p>

Comment puis-je l'étirer?


0 commentaires

3 Réponses :


0
votes

Supprimez les virgules de la valeur de votre grid-template-columns , alors vous n'avez pas à vous soucier du style des éléments individuels:

<div class="wrapper">
  <div class="item1">Item 1</div>
  <div class="item2">Item 2</div>
  <div class="item3">Item 3</div>

</div>
* {
  box-sizing: border-box;
}

.wrapper {
  border: 2px solid #f76707;
  border-radius: 5px;
  background-color: #fff4e6;
  display: grid;
  grid-template-columns: 100px 1fr 100px;
}

.wrapper>div {
  border: 2px solid #ffa94d;
  border-radius: 5px;
  background-color: #ffd8a8;
  padding: 1em;
  color: #d9480f;
}


0 commentaires

0
votes
* {box-sizing: border-box;}

.wrapper {
    border: 2px solid #f76707;
    border-radius: 5px;
    background-color: #fff4e6;
}

.wrapper > div {
    border: 2px solid #ffa94d;
    border-radius: 5px;
    background-color: #ffd8a8;
    padding: 1em;
    color: #d9480f;
}
.wrapper {
  display: grid;
  grid-template-columns: 100px 1fr 100px; /* there are no commas. */
  grid-template-rows: 1fr;

  grid-template-areas: "a b c";

}

.item2 {
  grid-area: b;
  justify-self:stretch;
} /* Item1 and Item2 automatically will be aligned at start and end. */

0 commentaires

0
votes

Supprimez simplement les virgules des valeurs de vos colonnes de modèle de grille.

 grid-template-columns: 100px 1fr 100px;

https://jsfiddle.net/3cv6ypq5/


0 commentaires