面试题 前端(二)元素显示模式 块元素行内元素区别

五、元素的显示模式 块元素、行内元素、行内块元素特点区别 常用标签

1.块元素/块级元素(block)

独占一行,从上到下排列;

默认宽度撑满父元素,默认高度由内容撑开;

可通过CSS设置宽高。

常见块元素:div、p、ul、li、table、h1-h6、form等

2.行内元素/内联元素(inline)

不独占一行,一行中不能容纳的会在下一行继续从左到右排列;

默认宽度、默认高度都由内容撑开;

不能通过CSS设置宽高(width 和 height)。(margin 和 padding 左右有效,上下无效)。

常见行内元素:span、a、i、label、strong、em等

3.行内块元素(inline-block)

除了可以通过CSS设置宽高外,其他和行内元素相同。

常见行内块元素:img、input、button、select等

4.如何把行内元素变为行内块元素或块元素?

设置元素display属性为 inline-block 或 block 。

5.空元素

上面的块元素、行内元素、行内块元素是从显示模式上区分的。

还有一种划分方式是从结构上看,即标签有没有闭合标签,能不能包裹内容。

例如<div></div>、<p></p>、<span></span>这一类标签有闭合标签,中间包裹内容,就不是空元素。

常见空元素:img、input、br、hr等。

六、display属性常用值

  1. block:块元素;

  2. inline:行内元素;

  3. inline-block:行内块元素;

  4. none:隐藏(下一题详细说明);

  5. flex:弹性盒布局,是现在最常用的布局方式。

七、display: none; 和 visibility: hidden; 的区别

两者都是 CSS 属性,用于控制元素的可见性。

1. display: none;

元素完全从文档流中移除,不仅不可见还不再占据空间;

页面布局会重新计算;

不参与任何交互;

子元素也全部消失。

2. visibility: hidden;

元素仍处于文档流中,不可见,但仍占据空间;

页面布局不会重新计算;

仍可交互只是不可见;

子元素会继承 visibility: hidden; ,若设置子元素 visibility: visible; 则子元素可以单独显示。

补充:这里可以搜一下文档流的概念,个人理解是文档流就像一群人在地上排队,有的人飘到天上就是脱离文档流,脱离之后排在后面的人就会往前挪补上这个人的位置。display: none;就相当于队伍里彻底没有这个人了,后面的人会补上,但 visibility: hidden; 只是让这个人隐身,实际上他还在,后面的人不能往前动。

写在后面:打算开一个八股系列,主要是想鼓励自己坚持学习。有错误的地方欢迎大家指出。

相关推荐
酉鬼女又兒2 小时前
零基础快速入门前端蓝桥杯 Web 备考:AJAX 与 XMLHttpRequest 核心知识点及实战(可用于备赛蓝桥杯Web应用开发)
前端·ajax·职场和发展·蓝桥杯·css3·js
Sammyyyyy2 小时前
Node.js、Bun 与 Deno,2026 年后端运行时选择指南
前端·后端·node.js·servbay
默 语2 小时前
Web Access:一个Skill,拉满Agent联网和浏览器能力
前端·agent·skill
攒了一袋星辰2 小时前
类抖音的高并发评论盖楼系统
服务器·前端·数据库
大胡子大叔2 小时前
React组件化实现程序化视频生成
前端·react.js·音视频
wjcroom2 小时前
融释涡旋理论-对狭义相对论和洛伦兹变换的兼容
开发语言·前端
2601_955354462 小时前
SEO新手如何快速入门学习
前端·学习·搜索引擎
小和尚敲木头2 小时前
router.push(‘/‘)跳转不触发重定向
开发语言·前端·javascript