.parent {
}
.enfant {
/* mettre en absolute et fixez la largeur à 100% */
}
Je suis le parent
Je suis son enfant
Depuis votre smartphone sur notes.mstechdays.fr
De nombreux lots à gagner toutes les heures.
Claviers, souris et jeux Microsoft...
Merci de nous aider à améliorer les Techdays!
Vincent De Oliveira · iamvdo
.element{
padding: 15px;
width: 98.32%; /* pas compris, mais ça déborde à 98.33% */
position: relative; /* faut pas enlever */
overflow: hidden; /* ça non plus, tout foire sinon */
z-index: 9875687; /* p***, ça veut pas passer au-dessus! */
}
<td>CSS sucks</td>
NOPE
Les feuilles de styles proviennent d'une source unique: nous!
FAUX
idclass, pseudo-classes, d'attributs.inner>ul>li>a#toto)
#toto 1,0,0.inner ul li a 0,1,3a:hover 0,1,1!important:not()Pour cibler un identifiant sans donner plus de spécificité, utilisez le sélecteur d'attribut.
[id=toto] est identique à #toto, mais avec la même spécificité qu'une class.
La valeur définie pour une propriété CSS est celle utilisée pour le rendu de la page
FAUX
* De toute façon, ce qui compte c'est les valeurs (Perceval, Kaamelott)
window.getComputedStyle(e)rgb(255,0,0) sur écran noir&blanc, etc.* De toute façon, ce qui compte c'est les valeurs (Perceval, Kaamelott)
La valeur calculée du mot-clé transparent pour les couleurs est rgba(0,0,0,0), soit du noir transparent.
width définit la largeur totale d'un élément
FAUX
width est la largeur du contenuwidth + padding + border
box-sizing modifie le calcul du modèle de boite
box-sizing: content-box: modèle CSS2.1box-sizing: border-box: modèle CSS3width devient la largeur totale
La largeur d'un block est égale à 100% de la largeur de son parent
FAUX
width est auto (pas 100%)padding et bordures!left et right
auto les deux: la largeur est shrink-to-fitleft et rightLa largeur en % d’un élément block est toujours calculée par rapport à celle de son parent
FAUX
position: static (tous) ou position: relative: c'est le parentposition: fixed: c'est le viewport (ou la page)position: absolute: c'est le premier parent en relative, absolute ou fixed (sinon le viewport).parent {
}
.enfant {
/* mettre en absolute et fixez la largeur à 100% */
}
Je suis le parent
Je suis son enfant
La propriété
display n'a que deux valeurs possibles: inline et block?
FAUX
block, inline, list-iteminline-blocktable, table-row, table-cell (modèle tabulaire)table-cell) peut être aligné verticalement avec vertical-align: top ou middle ou bottomL’ordre d’affichage des éléments (code source) peut être modifié, sans positionnement relatif, absolu ou fixe.
VRAI
table-row-group (groupe de lignes)table-header-group (groupe de lignes d'entête)table-footer-group (groupe de lignes de pied de page).enfant{
display: table-row;
}
.menu{
}
Un élément flottant peut devenir une cellule (ou une ligne) de tableau
FAUX
display:none
position et float sans effetsposition:absolute ou fixed
float est none, display ▸ tableaufloat:left ou right
display ▸ tableauhtml)
display ▸ tableaudisplay| Valeur spécifiée | Valeur calculée |
|---|---|
| inline-table | table |
| inline, table-row-group, table-column, table-column-group, table-header-group, table-footer-group, table-row, table-cell, table-caption, inline-block | block |
| block, list-item, table | valeur spécifiée |
.parent {
display: table-cell;
vertical-align: middle;
}
Un élément dont tous ses enfants sont flottants a une hauteur de 0
FAUX
Toute ressemblance avec une marque existante est purement fortuite.
floatposition: absolute ou fixeddisplay: inline-block ou table-cell ou table-captionoverflow != visible.enfant-left{
float: left;
}
.enfant-right{
/* Creer un BFC */
}
.parent{
}
.parent img{
float: left;
}
.parent{
/* Creer un BFC */
}
Oh les biens beaux kiwis!
clear empêche un élément d'être adjacent à un float (mais dans le même BFC).contenu h2 {
}
.menu {
float: left;
width: 200px;
}
.contenu {
margin-left: 200px;
/* Creer un BFC */
}
.contenu img {
float: left;
}
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Temporibus, ipsam, dolore similique harum asperiores possimus officiis.
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Magni, dolorum, alias, officia consequuntur delectus omnis dolorem ratione animi maiores accusantium ut harum blanditiis debitis quasi adipisci quod porro maxime corrupti.
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Sequi, delectus, eum, commodi blanditiis illo maxime fuga incidunt consequuntur vel nemo inventore quisquam architecto temporibus nobis deserunt totam perspiciatis quo natus? Lorem ipsum dolor sit amet, consectetur adipisicing elit. Veritatis rerum deserunt perferendis. Molestias, laudantium, doloremque voluptates dolores sequi hic facilis nobis sint eligendi ipsa architecto deleniti. Aperiam, soluta accusantium voluptas.
float, position: absolute
display: inline-block
display: table-cell
table, table-row)overflow: hidden
display: table
table-cell anonyme (donc BFC)table-layout: autotable-layout: fixedDeux éléments qui se suivent ayants des marges de 10px sont séparés de 20px
FAUX
height: auto)padding ou border sur le parent.enfant {
background: tomato;
}
.parent {
/*background: yellow;*/
}
Enfant 1
Enfant 2
Enfant 3
Une marge droite ou gauche en % se réfère à la largeur de l'élément qui le contient.
Une marge haute ou basse en % se réfère à la largeur(!) de l'élément qui le contient.
L’élément avec le
z-index maximal de la page sera toujours au dessus de tous les autres éléments
FAUX
html)position: absolute, relative ou fixed et z-index différent de autoz-index est relatif à son contexte!.enfant {
position: absolute;
}
.enfant--un {
z-index: 1;
}
.enfant--deux {
}
.parent--deux {
}
Il est possible de modifier l’ordre d’empilement sans
z-index
VRAI
background de l’élément racinez-index négatifsz-index autoz-index positifsz-index.enfant--un { /* red */
}
.enfant--deux { /* green */
}
.enfant span {
}
.enfant--un span { /* yellow */
}
.enfant--deux span { /* blue */
}
L’opacité modifie l’ordre d’affichage des éléments
VRAI
transform != nonetransform-style: preserve-3dfilter != noneclip-path, mask.parent { /* red */
}
.enfant { /* blue */
position: absolute;
z-index: -1;
}
Vincent De Oliveira · @iamvdo
Les slides: slides.iamvdo.me/techdays14
#mstechdays
