Maison> interface Web> tutoriel CSS> le corps du texte

利用CSS实现水平居中的4种思路简要概述

高洛峰
Libérer: 2017-03-13 17:38:27
original
1142 Les gens l'ont consulté

水平居中是经常遇到的问题。看似方法较多,条条大路通罗马。但系统梳理下,其实都围绕着几个思路展开。本文将介绍关于水平居中的4种思路,感兴趣的朋友参考下吧

前面的话

  水平居中是经常遇到的问题。看似方法较多,条条大路通罗马。但系统梳理下,其实都围绕着几个思路展开。本文将介绍关于水平居中的4种思路,感兴趣的朋友参考下吧!

思路一:在父元素中设置text-align:center实现行内元素水平居中

  将子元素的display设置为inline-block,使子元素变成行内元素

  [注意]若要兼容IE7-浏览器,可使用display:inline;zoom:1;来达到inline-block的效果

 

DEMO

Copier après la connexion


思路二:在本身元素设置margin: 0 auto实现块级元素水平居中


【1】将子元素的display为table,使子元素成为块级元素,同时table还具有包裹性,宽度由内容撑开

  [注意]若要兼容IE7-浏览器,可把child的结构换成

DEMO

 

DEMO

Copier après la connexion


【2】若子元素定宽,则可以使用绝对定位盒模型属性,实现居中效果;若不设置宽度时,子元素被拉伸

 

DEMO

Copier après la connexion


思路三: 通过绝对定位的偏移属性实现水平居中

【1】配合translate()位移函数

  translate函数的百分比是相对于自身宽度的,所以left:50%配合translateX(-50%)可实现居中效果

  [注意]IE9-浏览器不支持

 

DEMO

Copier après la connexion


【2】配合relative

  relative的偏移属性是相对于自身的,因为子元素已经被设置为absolute,所以若使用relative,则需要增加一层

结构,使其宽度与子元素宽度相同

  [注意]该方法全兼容,但是增加了html结构

 

DEMO

Copier après la connexion


【3】配合负margin

  margin的百分比是相对于包含块的,所以需要增加一层

结构。由于宽度width的默认值是auto,当设置负margin时,width也会随着变大。所以此时需要定宽处理

  [注意]虽然全兼容,但需要增加页面结构及定宽处理,所以限制了应用场景

 

DEMO

Copier après la connexion


思路四: 使用弹性盒模型flex实现水平居中

  [注意]IE9-浏览器不支持

【1】在伸缩容器上设置主轴对齐方式jusify-content:center

 

DEMO

Copier après la connexion


【2】在伸缩项目上设置margin: 0 auto

 

DEMO

Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Derniers numéros
Comment centrer un formulaire/tableau avec des jeux de champs en HTML-CSS et garder la taille cohérente ? En HTML en utilisant la combinaison de
et . Cela ressemble à cec...
Depuis 2023-09-16 11:49:52
0
1
803
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!