许多方法可以将HTML元素与CSS对齐,但是一起使用或单独使用它们并不是那么容易。开发人员所面临的困难之一就是试图将元素集中在页面中间。
因此,在本文中,我将展示一些最常用的方法,即通过使用不同的CSS属性在水平和垂直方向上居中图像。
让我们开始使用3个不同的CSS属性将图像水平居中。
使图像水平居中的第一种方法是使用text-align属性。但是,仅当图像位于块级容器(例如<div>)内时,此方法才有效:
使图像居中的另一种方法是使用margin:auto属性(用于左边距和右边距)。但是,单独使用margin:Auto将不适用于图像。如果需要使用margin:auto,则还必须使用2个其他属性。
margin-auto属性对内联级别的元素没有任何影响。由于<img>标签是一个内联元素,因此我们需要先将其转换为块级元素:
其次,我们还需要定义宽度。因此,左右边缘可以占用其余的空白空间并自动对齐,可以这样解决问题(除非我们给出100%的宽度):
将图像水平居中的第三种方法是使用display:flex。同样,我们对容器使用text-align属性,它也会使用display:flex。但是,仅使用display:flex是不够的。容器还必须具有一个称为justify-content的附加属性。
justify-content属性与display:flex一起使用,我们可以使用它水平放置图像的中心。最后,图像的宽度必须小于容器的宽度,否则,它会占用100%的空间,然后我们就无法对其进行集中化。
1、Display: Flex
对于垂直对齐,使用display:flex确实很有帮助。考虑到我们的容器的高度为800px,但图像的高度仅为500px:
现在,在这种情况下,向容器中添加一行代码(align-items:center)就可以了:
如果将align-items属性与display:flex一起使用,就会将元素垂直放置。
2、位置:绝对和变换属性
垂直对齐的另一种方法是一起使用position和transform属性。这个有点复杂,所以让我们一步一步地做。
步骤1:定义绝对位置
首先,我们将图像的定位行为从静态更改为绝对:
同样,它应该位于相对放置的容器内,因此我们添加一个位置:相对于其容器的div。
步骤2:定义顶部和左侧属性
其次,我们定义图像的顶部和左侧属性,并设置为50%。这会将图像的起点(左上角)移到容器的中心:
步骤3:定义变换属性
在第二步的时候已经将图像的一部分移出容器。因此,我们需要将其取回内部。在图像上定义转换属性,并在其X和Y轴上添加负50%可以达到目的:
还可以使用其他方法进行水平和垂直居中,我这里只尝试了最常用的方法。希望这篇文章可以帮助你了解如何在页面中心对齐图像。
r是一个块元素,其默认边界值是margin: 0 auto;。只需要通过css将其重置为margin: 0;即可。
.HTML 指的是?()
A.超文本标记语言(Hyper Text Markup Language)
B.家庭工具标记语言(Home Tool Markup Language)
C.超链接和文本标记语言(Hyperlinks and Text Markup Language)
2.Web 标准的制定者是?()
A.微软(Microsoft)
B.万维网联盟(W3C)
C.网景公司(Netscape)
3.在下列的 HTML 中,哪个是最大的标题?()
A.<h6>
B.<head>
C.<heading>
D.<h1>
4.在下列的 HTML 中,哪个可以插入折行?()
A.<br>
B.<lb>
C.<break>
5.在下列的 HTML 中,哪个可以添加背景颜色?()
A.<body color="yellow">
B.<background>yellow</background>
C.<body bgcolor="yellow">
6.请选择产生粗体字的 HTML 标签:()
A.<bold>
B.<bb>
C.<b>
D.<bld>
7.请选择产生斜体字的 HTML 标签:()
A.<i>
B.<italics>
C.<ii>
8.在下列的 HTML 中,哪个可以产生超链接?()
A.<a url="http://www.w3cschool.cn">W3Cschool.cn</a>
B.<a href="http://www.w3cschool.cn">W3Cschool</a>
C.<a>http://www.w3cschool.cn</a>
D.<a name="http://www.w3cschool.cn">W3Cschool.cn</a>
9.如何制作电子邮件链接?()
A.<a href="xxx@yyy">
B.<mail href="xxx@yyy">
C.<a href="mailto:xxx@yyy">
D.<mail>xxx@yyy</mail>
10.如何在新窗口打开链接?()
A.<a href="url" new>
B.<a href="url" target="_blank">
C.<a href="url" target="new">
11.请选择可以使单元格中的内容进行左对齐的正确 HTML 标签:()
A.<td align="left">
B.<td valign="left">
C.<td leftalign>
D.<tdleft>
13.如何产生带有圆点列表符号的列表?()
A.<dl>
B.<list>
C.<ol>
D.<ul>
14.在下列的 HTML 中,哪个可以产生复选框?()
A.<input type="check">
B.<checkbox>
C.<input type="checkbox">
D.<check>
15.在下列的 HTML 中,哪个可以产生文本框?()
A.<input type="textfield">
B.<textinput type="text">
C.<input type="text">
D.<textfield>
16.在下列的 HTML 中,哪个可以产生下拉列表?()
A.<list>
B.<input type="list">
C.<input type="dropdown">
D.<select>
17.在下列的 HTML 中,哪个可以产生文本区(textarea)?()
A.<textarea>
B.<input type="textarea">
C.<input type="textbox">
18.在下列的 HTML 中,哪个可以插入背景图像?()
A.<body background="background.gif">
B.<background img="background.gif">
C.<img src="background.gif" background>
19.以下选项中,哪个全部都是表格标签?()
A.<table><head><tfoot>
B.<table><tr><td>
C.<table><tr><tt>
D.<thead><body><tr>
20.在下列的 HTML 中,哪个可以插入图像?()
A.<img href="image.gif">
B.<image src="image.gif">
C.<img src="image.gif">
D.<img>image.gif</img>
请把你的答案写在留言区。^_^
*请认真填写需求信息,我们会在24小时内与您取得联系。