dispaly: inline-flex 和 display: flex 的区别

display: inline-flexdisplay: flex 都是 CSS 中用于创建弹性盒子布局(Flexbox)的属性值,但它们之间有一些关键的区别,主要体现在元素如何在页面上被渲染和它们对周围元素的影响。

主要区别

1,块级 vs 行内块级

display: flex:将一个元素设置为块级弹性容器。这意味着它会像其他块级元素(如 <div>)一样开始新的一行,并且可以设置宽度、高度等属性,不会与其他块级元素在同一行显示。

display: inline-flex:将一个元素设置为行内块级弹性容器。与 inline-block 类似,它允许该元素与其他行内元素在同一行显示,而不会强制新行开始。但是,它仍然保持了作为弹性容器的所有功能。

2,外部显示类型(External Display Type)

对于 display: flex,其外部显示类型为块级(block),这意味着它遵循块级元素的布局规则。

而 display: inline-flex 的外部显示类型为行内块级(inline-block),这使得它可以和其他行内元素一起出现在同一行内,除非空间不足导致换行。

3,布局影响

使用 display: flex 时,该元素会占据整个可用宽度(如果未明确指定宽度的话),并且通常会独占一行。

使用 display: inline-flex 时,元素仅占用其内容所需的宽度,并允许其他行内或行内块级元素与其并排显示在同一行中。

下面来看代码示例

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

<head>
	<meta charset="UTF-8">
	<meta name="viewport" content="width=device-width, initial-scale=1.0">
	<title>Document</title>
	<style>
		.flex .box {

			width: 500px;
			background: yellow;
			display: flex;
			justify-content: space-between;
		}

		.inline-flex .box {
			width: 500px;
			background: pink;
			display: inline-flex;
			justify-content: space-between;
		}
	</style>
</head>

<body>
	<div class="flex">
		<div class="box">
			<span>123</span>
			<span>456</span>
		</div>
		<span>额外的</span>
	</div>
	<div class="inline-flex">
		<div class="box">
			<span>123</span>
			<span>456</span>
		</div>
		<span>额外的</span>
	</div>
</body>

</html>

效果图

相关推荐
不一样的少年_3 分钟前
产品催: 1 天优化 Vue 官网 SEO?我用这个插件半天搞定(不重构 Nuxt)
前端·javascript·vue.js
-dcr5 分钟前
50.智能体
前端·javascript·人工智能·ai·easyui
行者9615 分钟前
Flutter跨平台开发适配OpenHarmony:进度条组件的深度实践
开发语言·前端·flutter·harmonyos·鸿蒙
云和数据.ChenGuang16 分钟前
Uvicorn 是 **Python 生态中用于运行异步 Web 应用的 ASGI 服务器**
服务器·前端·人工智能·python·机器学习
IT_陈寒17 分钟前
SpringBoot 3.0实战:这5个新特性让你的开发效率提升50%
前端·人工智能·后端
哈__22 分钟前
React Native 鸿蒙跨平台开发:LayoutAnimation 实现鸿蒙端页面切换的淡入淡出过渡动画
javascript·react native·react.js
winfredzhang24 分钟前
从零构建:基于 Node.js 的全栈视频资料管理系统开发实录
css·node.js·html·音视频·js·收藏,搜索,缩略图
遗憾随她而去.26 分钟前
Webpack 面试题
前端·webpack·node.js
我要敲一万行27 分钟前
前端文件上传
前端·javascript
恋猫de小郭29 分钟前
Tailwind 因为 AI 的裁员“闹剧”结束,而 AI 对开源项目的影响才刚刚开始
前端·flutter·ai编程