HTML给图片居中

在不同的布局场景下,让 <img> 元素居中的方法有所不同。下面为你介绍几种常见的居中方式

1. 块级元素下的水平居中

如果 <img> 元素是块级元素(可以通过 display: block 设置),可以使用 margin: 0 auto 来实现水平居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>水平居中图片</title>
    <style>
        img {
            display: block;
            margin: 0 auto;
        }
    </style>
</head>

<body>
    <img src="https://picsum.photos/200/300" alt="示例图片">
</body>

</html>
2. 内联元素下的水平居中

如果 <img> 元素是内联元素,可将其父元素的 text-align 属性设置为 center 来实现水平居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>水平居中图片</title>
    <style>
        .parent {
            text-align: center;
        }
    </style>
</head>

<body>
    <div class="parent">
        <img src="https://picsum.photos/200/300" alt="示例图片">
    </div>
</body>

</html>

垂直居中

1. 使用 flexbox 布局

可以使用 flexbox 布局来实现图片的垂直居中。将父元素设置为 display: flexdisplay: inline-flex,并使用 align-items: center 实现垂直居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>垂直居中图片</title>
    <style>
        .parent {
            display: flex;
            align-items: center;
            height: 300px;
            border: 1px solid #ccc;
        }
    </style>
</head>

<body>
    <div class="parent">
        <img src="https://picsum.photos/200/300" alt="示例图片">
    </div>
</body>

</html>

水平和垂直同时居中

1. 使用 flexbox 布局

通过 flexbox 布局可以轻松实现图片的水平和垂直同时居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>水平和垂直居中图片</title>
    <style>
        .parent {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 300px;
            border: 1px solid #ccc;
        }
    </style>
</head>

<body>
    <div class="parent">
        <img src="https://picsum.photos/200/300" alt="示例图片">
    </div>
</body>

</html>
2. 使用 positiontransform

同样,使用绝对定位和 transform 属性也能实现图片的水平和垂直同时居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>水平和垂直居中图片</title>
    <style>
        .parent {
            position: relative;
            height: 300px;
            border: 1px solid #ccc;
        }

        img {
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
        }
    </style>
</head>

<body>
    <div class="parent">
        <img src="https://picsum.photos/200/300" alt="示例图片">
    </div>
</body>

</html>
相关推荐
逃逸线LOF22 分钟前
CSS之精灵图(雪碧图)Sprites、字体图标
前端·css
进取星辰1 小时前
31、魔法生物图鉴——React 19 Web Workers
开发语言·javascript·ecmascript
海天胜景1 小时前
jqGrid冻结列错行问题,将冻结表格(悬浮表格)与 正常表格进行高度同步
前端
清风细雨_林木木2 小时前
解决 Tailwind CSS 代码冗余问题
前端·css
HSunR2 小时前
vue3 elementplus tabs切换实现
javascript·vue.js·elementui
搏博2 小时前
WPS中代码段的识别方法及JS宏实现
开发语言·javascript·wps
三天不学习2 小时前
VueUse/Core:提升Vue开发效率的实用工具库
前端·javascript·vue.js·vueuse
好青崧2 小时前
等于和绝对等于的区别
javascript
余道各努力,千里自同风3 小时前
CSS实现文本自动平衡text-wrap: balance
前端·css
半青年3 小时前
Qt图表库推荐指南与分析
c语言·开发语言·javascript·c++·qt·信息可视化