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>
相关推荐
咖啡の猫2 小时前
Shell脚本-for循环应用案例
前端·chrome
百万蹄蹄向前冲4 小时前
Trae分析Phaser.js游戏《洋葱头捡星星》
前端·游戏开发·trae
朝阳5815 小时前
在浏览器端使用 xml2js 遇到的报错及解决方法
前端
GIS之路5 小时前
GeoTools 读取影像元数据
前端
ssshooter5 小时前
VSCode 自带的 TS 版本可能跟项目TS 版本不一样
前端·面试·typescript
你的人类朋友6 小时前
【Node.js】什么是Node.js
javascript·后端·node.js
Jerry6 小时前
Jetpack Compose 中的状态
前端
dae bal7 小时前
关于RSA和AES加密
前端·vue.js
柳杉7 小时前
使用three.js搭建3d隧道监测-2
前端·javascript·数据可视化
lynn8570_blog7 小时前
低端设备加载webp ANR
前端·算法