Jadual Kandungan
目录
水平居中
对于行内元素的居中方法
对块级元素的居中方法
关于 margin: 0 auto; 的补充
垂直居中
行内元素的垂直居中
块状元素的垂直居中
水平垂直居中
固定宽高的居中方法
不固定/不确定高度的实现方法
Rumah hujung hadapan web html tutorial css实现居中_html/css_WEB-ITnose

css实现居中_html/css_WEB-ITnose

Jun 21, 2016 am 08:54 AM

目录

    1. 对于行内元素的居中方法
      1. 多个块状元素的居中方法
      2. 多个块状元素在竖直方向上堆在一起居中的方法
      1. 在不知道/不固定高度的情况下
    1. 不固定/不确定高度的实现方法

本文是对 centering-css-complete-guide 这篇文章的不完全翻译,其中有部分是按照自己的理解,由于英文水平和css水平都一般般,所以文章有翻译/理解错误或其他问题,请多多指教。

原文地址: https://css-tricks.com/centering-css-complete-guide/

原文作者:CHRIS COYIER

水平居中

对于行内元素的居中方法

对于行内元素水平居中,需要将块状的父级元素的样式设置为:

.center-childred { text-align: center;}
Salin selepas log masuk

比如,将一个a链接或文本元素居中的例子:

See the Pen Centering Inline Elements by Chris Coyier ( @chriscoyier ) on CodePen .

这种方法对于 inline , inline-block , inline-table , inline-flex 等都适用。

对块级元素的居中方法

你可以通过给一个块级元素设置 margin-left 和 margin-right 为auto,来实现水平居中,不过块状元素需要给定宽度,否则它会全宽而不是居中。设置方法如下:

.center-me { margin: 0 auto;}
Salin selepas log masuk

当块状元素设置宽度时,使用 margin: 0 auto; 会使该元素居中.居中的原理stackoverflow上有个详细的描述:

When you have specified a width on the object that you have applied margin: 0 auto to, the object will sit centrally within it’s parent container.

Specifying auto as the second parameter basically tells the browser to automatically determine the left and right margins itself, which it does by setting them equally. It guarantees that the left and right margins will be set to the same size. The first parameter 0 indicates that the top and bottom margins will both be set to 0.

margin-top:0;

margin-bottom:0;

margin-left:auto;

margin-right:auto;

Therefore, to give you an example, if the parent is 100px and the child is 50px, then the auto property will determine that there’s 50px of free space to share between margin-left and margin-right:

var freeSpace = 100 - 50;

var equalShare = freeSpace / 2;

Which would give:

margin-left:25;margin-right:25;

下面是演示:

See the Pen 块状元素居中 by guihailiuli ( @guihailiuli ) on CodePen .

可以试下,当把 width: 400px; 注释掉后,div就不是居中而是从左到右撑满容器。

使用这种方法,当该块状元素的宽度大于父级元素的宽度,就会子元素的宽度超过父元素宽度进而无法实现居中,你可以把 width: 600px; 试试看。

关于 margin: 0 auto; 的补充

  1. 设置块级元素的 width 可以阻止它从左到右撑满容器。然后你就可以设置左右外边距为 auto 来使其水平居中。元素会占据你所指定的宽度,然后剩余的宽度会一分为二成为左右外边距。

  2. 当浏览器窗口比元素的宽度还要窄时,浏览器会显示一个水平滚动条来容纳页面,在这种情况下使用 max-width 替代 width 可以使浏览器(包括IE7+在内都支持 max-width )更好地处理小窗口的情况。这点在移动设备上显得尤为重要.

  3. 有时不经意对要居中的最外层设置float:left或float:right也是造成设置margin:0 auto布局不能水平居中。原因是因为{margin: 0 auto;}是 可以让有宽度属性的块级元素水平居中。但它通常只对静态元素(无浮动、无定位)起作用,当元素被声明为浮动元素,它的布局会被移出文档流,auto的居中就不生效了。

在github上看到有对 margin: 0 auto; 的很精彩的评论,原文如下:

这段代码的作用,是个前端都能看懂:让块元素水平居中。一般大家都会写成:

.content {

width: 980px;

margin: 0 auto;

}

上面的代码能正常工作,大部分情况下也不会有问题,但上面的代码存在思维的懒惰。写成:

.content {

width: 980px;

margin-left: auto;

margin-right auto;

}

看起来代码变多了,变啰嗦了。但如果你真经过思考,就会明白:

  1. margin: 0 auto 中的 0 绝大部分情况下是冗余的,页面上早就有 reset.css 或 normalize.css 重置过
  2. margin: 0 auto 不纯粹,你要的是“水平居中”,却顺便把 top / bottom 给重置了 不纯粹会导致顺序和优先级的依赖,比如有另一处要给 margin-top/bottom 赋值时,就必须要提高优先级

进一步的东西是,我一直觉得CSS里,有一个重要的原则: 最小影响原则

你在写某段CSS代码时,首先要非常清楚地知道这段CSS代码的功能,其次要尽量严格保障这段CSS代码只实现了你想要实现的功能。

这就如医生动手术,好好做好本分就行,千万别留下一个小镊子在病人身体里。

与HTML代码一样,对CSS代码来说,很重要的两个衡量标准也是稳定和灵活。这里不多说了。

熟悉设计模式的,应该会感知到,最小影响原则和单一职责原则(SRP)本质上是一样的。SRP 作为设计模式的重要原则之一,其重要性不用我在此啰嗦了。

多个块状元素的居中方法

如果有多个块状元素需要水平居中在一行,很可能你会想到改变他们的display属性为 inline-block ,或者用flexbox。

例如:

See the Pen Centering Row of Blocks by Chris Coyier ( @chriscoyier ) on CodePen .

多个块状元素在竖直方向上堆在一起居中的方法

这种情况使用 margin: 0 auto; 一样有效

See the Pen Centering Blocks on Top of Each Other by Chris Coyier ( @chriscoyier ) on CodePen .

垂直居中

行内元素的垂直居中

对单行元素

一些行内元素/文本元素,将他们padding的top和bottom值设为一致就可以

.link { padding-top: 30px; padding-bottom: 30px;}
Salin selepas log masuk

对单行元素进行垂直对齐:

See the Pen Centering text (kinda) with Padding by Chris Coyier ( @chriscoyier ) on CodePen .

如果出于一些原因不想选择 padding ,在居中文本时一样可以使用 line-height ,可以使文本的高度处于中心

.center-text-trick { height: 100px; line-height: 100px; white-space: nowrap;}
Salin selepas log masuk

效果如下:

See the Pen Centering a line with line-height by Chris Coyier ( @chriscoyier ) on CodePen .

对多行元素

针对这种情况可以使用 vertical-align

See the Pen Centering text (kinda) with Padding by Chris Coyier ( @chriscoyier ) on CodePen .

如果不使用table,也可以使用flexbox, 用法如下:

.flex-center-vertically { display: flex; justify-content: center; flex-diretion: column; height: 400px;}
Salin selepas log masuk

效果:

See the Pen Vertical Center Multi Lines of Text with Flexbox by Chris Coyier ( @chriscoyier ) on CodePen .

使用这种方法需要相关的父元素有一个固定的高度(px,%等)

还有第三种方法是采用称为 ghost element 的技术,

用法如下:

.ghost-center { position: relative;}.ghost-center::height { content: " "; display: inlie-block; height: 100%; width: 1%; vertical-align: middle;}.ghost-center p { display: inline-block; vertical-align: middle;}
Salin selepas log masuk

效果:

See the Pen Ghost Centering Multi Line Text by Chris Coyier ( @chriscoyier ) on CodePen .

PS:个人水平太菜,对这种ghost element方法不懂,只是从原文搬过来,具体介绍请查看原文。

块状元素的垂直居中

在大多数页面布局中,高度是不知道的,比如当页面宽度发生变化时, text reflow 会使高度发生变化,当图片宽度调整时也会改变高度,等等情况

但是,如果知道了高度,就可以用下面的居中方法。

在固定高度的情况下

使用方法:

.parent { position: relative;}.child { position: absolute; top: 50%; height: 100px; margin-top: -50px;}
Salin selepas log masuk

实现的原理:

实现效果:

See the Pen Center Block with Fixed Height by Chris Coyier ( @chriscoyier ) on CodePen .

在不知道/不固定高度的情况下

这种情况下可以通过 transform: translateY() 方法推动块状元素一半的高度来实现居中.

使用方法:

.parent { position: relative;}.child { position: absolute; top: 50%; transform: translateY(-50%);}
Salin selepas log masuk

关于 transform: translate() 方法的补充:

translate 表示移动,该属性值含 3 种情况:translate(x,y) 水平方向和垂直方向同时移动(也就是 X 轴和 Y 轴同时移动,即斜一定角度移动);translateX(x) 仅水平方向移动(X 轴移动);translateY(Y) 仅垂直方向移动(Y 轴移动),举个例子:

transform:translateY(20px); // 表示由基点处沿垂直方向向下移动 20px
Salin selepas log masuk

实现效果:

See the Pen Center Block with Unknown Height by Chris Coyier ( @chriscoyier ) on CodePen .

当然,也可以用flexbox实现:

.parent { display: flex; flex-direction: column; justify-content: center;}
Salin selepas log masuk

实现效果:

See the Pen Center Block with Unknown Height with Flexbox by Chris Coyier ( @chriscoyier ) on CodePen .

水平垂直居中

固定宽高的居中方法

利用 负margin 技术实现

.parent { position: relative;}.child { width: 300px; height: 100px; padding: 20px; position: absolute; top: 50%; left: 50%; margin: -70px 0 0 -170px;}
Salin selepas log masuk

实现效果:

See the Pen Center Block with Fixed Height and Width by Chris Coyier ( @chriscoyier ) on CodePen .

不固定/不确定高度的实现方法

可以通过两个方向都使用 transform: translate; 来实现

使用方式:

.parent { position: relative;}.child { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}
Salin selepas log masuk

实现效果:

See the Pen Center Block with Unknown Height and Width by Chris Coyier ( @chriscoyier ) on CodePen .

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Kesukaran mengemas kini caching laman web akaun rasmi: Bagaimana untuk mengelakkan cache lama yang mempengaruhi pengalaman pengguna selepas kemas kini versi? Kesukaran mengemas kini caching laman web akaun rasmi: Bagaimana untuk mengelakkan cache lama yang mempengaruhi pengalaman pengguna selepas kemas kini versi? Mar 04, 2025 pm 12:32 PM

Cache kemas kini laman web akaun rasmi, perkara ini mudah dan mudah, dan ia cukup rumit untuk minum periuknya. Anda bekerja keras untuk mengemas kini artikel akaun rasmi, tetapi pengguna masih membuka versi lama. Dalam artikel ini, mari kita lihat kelainan dan bertukar di belakang ini dan bagaimana menyelesaikan masalah ini dengan anggun. Selepas membacanya, anda boleh dengan mudah menangani pelbagai masalah caching, yang membolehkan pengguna anda sentiasa mengalami kandungan segar. Mari kita bincangkan asas -asas terlebih dahulu. Untuk meletakkannya secara terang -terangan, untuk meningkatkan kelajuan akses, penyemak imbas atau pelayan menyimpan beberapa sumber statik (seperti gambar, CSS, JS) atau kandungan halaman. Kali seterusnya anda mengaksesnya, anda boleh mengambilnya secara langsung dari cache tanpa perlu memuat turunnya lagi, dan ia secara semula jadi cepat. Tetapi perkara ini juga pedang bermata dua. Versi baru dalam talian,

Bagaimana saya menggunakan atribut pengesahan borang html5 untuk mengesahkan input pengguna? Bagaimana saya menggunakan atribut pengesahan borang html5 untuk mengesahkan input pengguna? Mar 17, 2025 pm 12:27 PM

Artikel ini membincangkan menggunakan atribut pengesahan bentuk HTML5 seperti had, corak, min, max, dan panjang untuk mengesahkan input pengguna secara langsung dalam penyemak imbas.

Bagaimana cara menambah kesan strok kepada imej PNG di laman web? Bagaimana cara menambah kesan strok kepada imej PNG di laman web? Mar 04, 2025 pm 02:39 PM

Artikel ini menunjukkan penambahan sempadan PNG yang cekap ke halaman web menggunakan CSS. Ia berpendapat bahawa CSS menawarkan prestasi unggul berbanding dengan JavaScript atau perpustakaan, memperincikan cara menyesuaikan lebar sempadan, gaya, dan warna untuk kesan halus atau menonjol

Apakah amalan terbaik untuk keserasian penyemak imbas dalam HTML5? Apakah amalan terbaik untuk keserasian penyemak imbas dalam HTML5? Mar 17, 2025 pm 12:20 PM

Artikel membincangkan amalan terbaik untuk memastikan keserasian silang pelayar HTML5, memberi tumpuan kepada pengesanan ciri, peningkatan progresif, dan kaedah ujian.

Apakah tujuan & lt; DATALIST & GT; unsur? Apakah tujuan & lt; DATALIST & GT; unsur? Mar 21, 2025 pm 12:33 PM

Artikel ini membincangkan html & lt; datalist & gt; elemen, yang meningkatkan bentuk dengan menyediakan cadangan autokomplete, meningkatkan pengalaman pengguna dan mengurangkan kesilapan. Kira -kira: 159

Apakah tujuan & lt; kemajuan & gt; unsur? Apakah tujuan & lt; kemajuan & gt; unsur? Mar 21, 2025 pm 12:34 PM

Artikel ini membincangkan html & lt; kemajuan & gt; elemen, tujuan, gaya, dan perbezaan dari & lt; meter & gt; elemen. Tumpuan utama adalah menggunakan & lt; kemajuan & gt; untuk menyelesaikan tugas dan & lt; meter & gt; untuk stati

Bagaimana saya menggunakan html5 & lt; masa & gt; elemen untuk mewakili tarikh dan masa secara semantik? Bagaimana saya menggunakan html5 & lt; masa & gt; elemen untuk mewakili tarikh dan masa secara semantik? Mar 12, 2025 pm 04:05 PM

Artikel ini menerangkan html5 & lt; time & gt; elemen untuk perwakilan tarikh/masa semantik. Ia menekankan pentingnya atribut DateTime untuk pembacaan mesin (format ISO 8601) bersama teks yang boleh dibaca manusia, meningkatkan aksesibilit

Apakah tujuan & lt; meter & gt; unsur? Apakah tujuan & lt; meter & gt; unsur? Mar 21, 2025 pm 12:35 PM

Artikel ini membincangkan html & lt; meter & gt; elemen, digunakan untuk memaparkan nilai skalar atau pecahan dalam julat, dan aplikasi umum dalam pembangunan web. Ia membezakan & lt; meter & gt; dari & lt; kemajuan & gt; dan Ex

See all articles