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 分钟前
用trae整了个记账APP(带AI功能)
前端·react native·程序员
梦想的旅途23 分钟前
JS 注入与 DOM 操作:Web 企业微信 RPA 的交互增强
前端·javascript·企业微信
chenjianzhong4 分钟前
vue-cli4.x + Typescript总结
前端
浪浪山_大橙子5 分钟前
🤖 电脑智能助手:用Trae打造的Electron+大模型自动化工具
前端·javascript
北辰alk5 分钟前
React 的 setState 批量更新机制详解
前端·react.js
qq13267029405 分钟前
后端开发接受Vue项目踩坑记录
前端·javascript·vue.js
jerry_kong7 分钟前
扫码枪卡顿有效解决方案
前端
努力的小郑7 分钟前
MCP 完全指南(上):撕掉标签,看清本质
前端·后端·ai编程
写代码的皮筏艇9 分钟前
取消axios请求
前端·javascript
车前端9 分钟前
前端异常监控:如何捕获页面中的 XHR 和 Fetch 请求错误
前端