CSS中display:inline 和 inline-block的区别

首先看看来自chatgpt的回答:

inlineinline-block 是两种 CSS 属性值,它们都用于控制元素在水平方向上排列,并与文本流中的其他元素一起显示。它们之间的主要区别在于如何处理元素的宽度和高度以及如何与其他元素排列。

  1. inline

    • inline 元素会像文本一样在一行内排列,不会独占一行,只占据其内容所需的水平空间。
    • inline 元素的宽度和高度由其内容决定,不可以设置固定的宽度和高度。
    • inline 元素的 marginpadding 对左右方向有效,但不对上下方向有效。
    • inline 元素与相邻的元素之间可能存在一些默认的水平间距,这通常由字母间距和换行符等因素引起。
  2. inline-block

    • inline-block 元素也会在一行内排列,但与 inline 不同的是,它可以设置固定的宽度和高度。
    • inline-block 元素的宽度和高度可以通过 CSS 明确指定,因此具有更多的布局自由度。
    • inline-block 元素的 marginpadding 对所有方向都有效,包括上下方向。
    • inline-block 元素之间的默认水平间距通常较小,且可以通过调整 font-sizeletter-spacing 来消除。

总结来说,inline 适用于需要元素在一行内显示,并且宽度和高度由内容决定的情况,而 inline-block 更适合需要元素在一行内显示,但又希望具有更精确控制宽度、高度以及上下间距的情况。根据具体的布局需求和设计目标,可以选择使用其中之一。

总结:二者都是让元素能够在同一行显示,区别在于:

**   inline: 不能设置宽高和间距,只能由元素内容自动撑开**

适用场景:让块级元素同一行显示: 比如ul标签

**inline-block: 可以对行内元素设置宽高和间距,**比如a标签

相关推荐
秋水无痕13 分钟前
# 手把手教你从零搭建 AI 对话系统 - React + Spring Boot 实战(一)
前端·后端
高桥凉介发量惊人15 分钟前
基础与工程篇-多环境配置(dev/test/prod)与打包策略
前端
墨鱼笔记16 分钟前
前端必看:Vite.config.js 最全配置指南 + 实战案例
前端·vite
kyriewen17 分钟前
异步编程:从“回调地狱”到“async/await”的救赎之路
前端·javascript·面试
前端Hardy20 分钟前
别再手动写 loading 了!封装一个自动防重提交的 Hook
前端·javascript·vue.js
前端Hardy21 分钟前
前端如何实现“无感刷新”Token?90% 的人都做错了
前端·javascript·vue.js
秋水无痕22 分钟前
# 手把手教你从零搭建 AI 对话系统 - React + Spring Boot 实战(二)
前端·后端·面试
SuperEugene30 分钟前
Vue Router 实战规范:path/name/meta 配置 + 动态 / 嵌套路由,统一团队标准|状态管理与路由规范篇
开发语言·前端·javascript·vue.js·前端框架
小彭努力中1 小时前
194.Vue3 + OpenLayers 实战:动态位置 + 高度 + 角度,模拟卫星地面覆盖范围
前端·css·vue.js·openlayers·animate
颜正义1 小时前
作为前端你还不会 Playwright 进行单元测试吗?
前端·测试