Maison  >  Article  >  interface Web  >  Analyse de l'utilisation et des problèmes courants de marge en CSS

Analyse de l'utilisation et des problèmes courants de marge en CSS

小云云
小云云original
2017-12-19 10:45:522503parcourir

Nous connaissons très bien margin.Cet article présente principalement l'utilisation de margin en CSS et l'analyse des problèmes courants.L'introduction dans l'article est très détaillée et a une certaine valeur de référence et d'apprentissage pour tous les amis qui en ont besoin. suivez Jetons un coup d'oeil ensemble.

1. Introduction

marge Nous avons généralement l'habitude de l'appeler marges. Nous pouvons définir les marges dans quatre directions respectivement. ici. Décrivez la syntaxe d'affectation en détail.

En fait, les marges que nous définissons habituellement sont des paramètres de niveau physique, et les marges incluent également le début, la fin, avant, après, etc. Ce sont principalement des paramètres de niveau logique. Si vous êtes intéressé, recherchez-le vous-même sur Google.

Lors de la définition de la marge, nous devons savoir :

  • Pour les éléments au niveau du bloc, quelle est l'efficacité de la marge dans quatre directions

  • Pour les éléments en ligne, la marge ne fonctionne qu'horizontalement.


2. Modèle de boîte

En parlant de marge, je dois parler du modèle de boîte :

1. Du contenu intérieur et extérieur => rembourrage => bordure => marge


La raison pour laquelle le modèle de boîte doit être compris à la fin est principalement due aux normes. du modèle de boîte sont différents. Cela détermine la largeur que nous définissons en CSS. À ce moment-là, tout le monde pensera à ces formules de calcul. En fait, avec l'arrivée de CSS3, nous pouvons définir la norme du modèle de boîte via box. -sizing :

2. border-box : la largeur est calculée à partir de la bordure


3. content-box : la largeur est calculée à partir du contenu ; >4. padding-box : a été calculé à partir de la suppression de la norme.


Voici une autre photo, vous la comprenez déjà bien ?


Problème de chevauchement des marges

Ce problème se produit principalement sur les éléments blocs et non sur les éléments flottants (il n'est pas décrit clairement ici, et sera discuté en détail plus tard).

1. Se produit lorsque des éléments frères adjacents


    .a {
        margin: 50px 0;
    }
    .b {
        margin: 100px 0;
    }
se chevauchent. des éléments frères

Dans ce cas, un chevauchement de marge se produit. La distance entre les nœuds frères adjacents est la valeur de marge maximale. La meilleure façon d'éviter cette situation est de définir uniquement la marge supérieure. ou marge inférieure.


2. Se produit au niveau du nœud parent-enfant


    p(class="b")
    p(class="a")
        p(class="c") C


    .a {
        margin: 20px 0;
    }
    .b {
        margin: 100px 0;
    }
Un chevauchement de marge se produit entre les nœuds parent et enfant

Selon notre compréhension ici, la distance entre a et b devrait être de 20 pixels, et la distance entre c et a vaut 100 pixels. Mais ce n'est pas le cas. Ici, nous pouvons résoudre le problème de chevauchement grâce aux méthodes suivantes :


L'élément parent définit la bordure ; L'élément parent définit le remplissage

  • L'élément parent définit le débordement sur caché ou défilant, les autres ne sont pas applicables

  • L'élément parent définit la position sur ; fixes ou absolus, d'autres non applicables.

  • 4. Valeur de marge négative magique
  • Nous définissons la marge dans quatre directions pour un élément de bloc Que se passe-t-il :

Définir des valeurs négatives pour le haut et la gauche déplacera l'élément vers le haut ou vers la gauche de la distance de pixel correspondante

Définir le bas et la droite ; Les valeurs négatives déplaceront les éléments adjacents vers le haut ou vers la gauche.

  • Il y a un autre point ici. Lorsque j'ai vérifié les informations, j'ai constaté que beaucoup de gens disaient qu'une marge négative pouvait modifier la largeur de l'élément. Je voudrais le corriger ici. n'est pas une caractéristique d'une marge négative, mais les caractéristiques d'une marge. Par exemple, le CSS suivant peut définir complètement la largeur des éléments au niveau du bloc.

  • L'affectation de marge est largement utilisée dans la mise en page. Par exemple, si nous connaissons la largeur et la hauteur d'un élément, vous pouvez le centrer via des valeurs de marge négatives.


    .item {
        margin: 0 200px;
        height: 200px;
    }

5 Marge et flotteur


Pour ces deux attributs gênants mélangés ensemble, je je veux juste dire que c'est vraiment explosif. J'ai dit plus haut que "ce problème se produit principalement sur les éléments blocs et non sur les éléments flottants". Voici encore deux points :
    .item {
        position: absolute;
        background: red;
        width: 200px;
        height: 200px;
        top: 50%;
        left: 50%;
        margin-top: -100px;
        margin-left: -100px;
    }

Éléments frères adjacents, si les deux sont des éléments flottants, pas de marge. un chevauchement se produira ;

éléments parent-enfant, si l'un d'eux est un élément flottant, le chevauchement des marges ne se produira pas

  • Principalement parce que les éléments flottants ne font pas partie du flux normal de documents, il est donc préférable d'utiliser la méthode d'effacement des flottants. (Ce qui suit est l'implémentation de bootstrap)

  •     .clearfix::before, .clearfix::after {
            content: " ";
            display: table;
        }
    
        .clearfix::after {
            clear: both;
        }

    学完本文相信大家对css 中margin属性有更深的认识,大家赶紧收藏起来吧。

    相关推荐:

    CSS的margin有什么作用

    有关margin负值浅析

    分享一篇关于margin的相关技巧

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn