28172 sujets

CSS et mise en forme, CSS3

Bonjour à tous,

J'ai créé une liste li en y insérant plusieurs éléments img, de taille différente.

J'ai ensuite disposés ces éléments horizontalement en utilisant la propriété display : inline-block.

Les éléments s'affichent horizontalement, alignés selon leurs bords inférieurs, mais je souhaiterai les aligner selon leurs centres respectifs.

Ci-joint une image pour expliciter mon propos. En gros je voudrais que les éléments du menu soient alignés selon l'axe bleu, et pas selon l'axe noir comme c'est le cas actuellement.

upload/1584875291-79217-capture.png

Voici mon code html et css

HTML :

<nav id="agama-primary-nav" class="tv-d-none tv-d-lg-block" role="navigation">
<ul id="menu-primary-menu" class="agama-navigation sf-js-enabled" style="touch-action: pan-y;">
<li id="Accueil" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-8">
<a href="http://mineralitude.com/">
<img class="accueil" src="accueil.png" alt="Accueil"/>
</a>
</li>
<li id="Articles" class="menu-item menu-item-type-taxonomy menu-item-object-category menu-item-54">
<a href="http://mineralitude.com/index.php/category/articles/">
<img class="articles" src="articles.png" alt="Articles"/>
</a>
</li>
<li id="A propos" class="menu-item menu-item-type-taxonomy menu-item-object-category menu-item-54">
<a href="http://mineralitude.com/index.php/category/a-propos/">
<img class="a-propos" src="a-propos.png" alt="A propos"/>
</a>
</li>
<li id="Contact" class="menu-item menu-item-type-taxonomy menu-item-object-category menu-item-54">
<a href="http://mineralitude.com/index.php/category/contact/">
<img class="contact" src="contact.png" alt="Contact"/>
</a>
</li>
</ul>
</nav>

CSS :

nav{
text-align: center;
}

li {
display: inline-block;
}

D'avance merci !
Modifié par moussolene (22 Mar 2020 - 12:09)
Administrateur
moussolene a écrit :
J'ai essayé mais ça ne marche pas...

Hello,

Ce sont les li que tu veux centrer ? Ou bien les contenus des li ?

Centrer verticalement à l'intérieur des li est assez simple:


li {
  display: inline-flex;
  align-items: center;
}
Bonjour @Raphael,

J'ai déjà réussi à centrer mes li, en utilisant
nav{
text-align: center;
}

Mais j'aimerais que me li soient alignés les uns par-rapport aux autres selon un axe central, et pas selon leur bord inférieur.
Ci-joint un schéma qui explicite mieux mon propos.

upload/1584888194-79217-capture.png

J'espère que c'est plus clair
Mais ceci dit, même en utilisant li {
display: inline-flex;
align-items: center;
}

ça ne marche pas.

Si cela peut aider, par défaut j'ai ces styles appliqués à
ul, li {
margin: 0;
padding: 0;
border: 0;
font-size: 100%;
vertical-align: baseline;
}
C'est bon, ça marche !!! Super, merci à tous Smiley smile )
Bon courage si vous êtes en confinement, et à bientôt (je suis en plein auto-formation, je risque de repasser souvent sur le forum)