La widthpropriété en CSS spécifie la largeur de la zone de contenu de l'élément. Cette zone de «contenu» est la partie à l'intérieur du remplissage, de la bordure et de la marge d'un élément (le modèle de boîte).
.element ( width: 80%; )
Dans l'exemple ci-dessus, les éléments dont le nom de classe .wrapest égal à 80% de la largeur de leur élément parent. Les valeurs acceptées sont l'une des valeurs de longueur, en plus de certains mots clés que nous aborderons plus tard.
La largeur peut être remplacée par les propriétés étroitement corrélées min-width et max-width.
.wrapper-1 ( width: 100%; max-width: 320px; /* Will be AT MOST 320px wide */ ) .wrapper-2 ( width: 100%; min-width: 20em; /* Will be AT LEAST 20em wide */ )
Creuser plus profond
Lors de l'utilisation du pourcentage (%) pour la largeur, les auteurs doivent savoir que le pourcentage est basé sur le parent de l'élément, ou en d'autres termes, la largeur du bloc conteneur. Si votre parent est défini sur 480 pixels - comme le montre notre démonstration - alors le pourcentage est basé sur cette valeur. Donc, dans notre cas, 50% de 480px nous laisse avec 240px comme valeur de pixel calculée.
Notez que cela widths'applique à tous les éléments à l'exception des éléments non remplacés ou en ligne, des lignes de tableau et des groupes de lignes (c'est thead-à- dire tfootet tbody). Il semble y avoir un léger décalage en ce qui concerne la façon dont HTML définit les éléments non remplacés et la façon dont CSS les définit, mais nous y faisons référence comme le fait CSS: des éléments dont le contenu n'est pas défini par la balise elle-même, comme unCodePen Embed Fallback
Keyword values
With some special keyword values, it is possible to define width (and/or height) according to the content of the element.
min-content
The min-content value is the smallest measure that would fit around its content if all soft wrap opportunities within the box were taken.
The best example for this kind of value is a properly written figure element:
What a lovely kitten we got there in this image which is encapsulated in a figure element. How dear, look how long this caption is!
Once we have applied some basic styles to this markup, we get:
If we wanted that figure element to essentially be the size of that image, so the text wraps at the edges of the image. We could float it left or right, because float will exhibit that same kind of shrink-to-fit behavior, but what if we wanted to center it? min-content allows us to center it:
Because we’ve assigned min-content to the figure element, it takes the minimum width it can have when taking all soft wrap opportunities (like spaces between words) so that the content still fits in the box.
max-content
The max-content property refers to the narrowest measure a box could take while fitting around its content - if no soft wrap opportunities within the element were taken.
Check out what happens if we apply this to our simple kitten/figure demo:
Because the caption is very longer than the image is wide (it doesn’t take any soft wrap opportunity, like the spaces between words), it means it has to display the caption on a single line, thus the figure is as wide as that line.
fill-available
???. One of life’s great mysteries.
fit-content
The fit-content value is roughly equivalent to margin-left: auto and margin-right: auto in behaviour, except it works for unknown widths.
For instance, let’s say we need to center an inline navigation across the page. Your best bet would be to apply text-align: center to the ul, and display: inline-block to the li. This would give you something like this:
However, the blue background (from the ul element) spreads across the entire document because the ul is a block-level element, which means its width is restricted only by its containing element. What if we want to have the blue background collapsing around the list items? fit-content to the rescue!
With fit-content and margin: 1em auto, this works like a charm and only the navigation has a colored background, not the whole document width.
If you’re into this sort of thing, you’ll be happy to know the formula to define the size of a fit-content length is: