Enfreindre la règle CSS : éléments en ligne contenant des éléments de bloc
Traditionnellement, l'imbrication d'éléments de bloc dans des éléments en ligne était considérée comme une violation de la structure HTML. Cependant, en HTML5, cette pratique devient autorisée. Cela signifie-t-il qu'il est acceptable de convertir un élément de bloc en élément de bloc même s'il contient un autre élément de bloc ?
Vue de la spécification CSS
Selon la spécification CSS 2.1, lorsqu'un élément en ligne contient un élément de niveau bloc, l'élément en ligne se divise en deux zones distinctes, entourant l'élément de bloc et ses frères et sœurs consécutifs au niveau de bloc. Ces boîtes de bloc anonymes qui en résultent deviennent les frères et sœurs de l'élément en ligne d'origine.
Exemple :
Considérez le balisage HTML et les règles CSS suivants :
<div><p>This is a paragraph</p></div>
div { display: inline; }
Dans ce scénario, le div devient en ligne, tandis que l'élément p reste au niveau du bloc par défaut. Selon CSS 2.1, cela entraîne la division du div en deux zones de bloc anonymes autour de l'élément p.
Implémentation et validité du navigateur
La spécification CSS fournit des conseils sur comportement du navigateur, mais la cohérence de la mise en œuvre et l'interprétation entre les navigateurs modernes peuvent varier. Le fait qu'une telle imbrication soit considérée comme valide ou non après l'application des règles CSS dépend du navigateur particulier et de sa mise en œuvre.
Conclusion
Alors que HTML5 permet d'imbriquer des éléments de bloc en ligne éléments, la conversion d'un élément block en inline lorsqu'il contient déjà un élément block présente une zone grise. Le comportement est techniquement spécifié en CSS mais sujet à l'interprétation et à la mise en œuvre du navigateur. Il est crucial de prendre en compte la compatibilité du navigateur et le comportement prévu de votre application Web avant d'employer cette pratique.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!