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

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

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 分钟前
Webpack 核心原理与自定义 Loader/Plugin 实战
前端·javascript
智码看视界9 分钟前
Web Storage 的无障碍实践与工程化应用
前端·javascript·web
孟陬11 分钟前
国外技术周刊 #140:在 Jeff Bezos 的私密 Campfire 峰会上,我学到了关于亿万富翁的事
前端·后端
槑有老呆12 分钟前
Bun:一个让 Node 开发者原地起飞的 JS/TS 运行时
前端
小小小小宇13 分钟前
AI Agent 核心流程与底层逻辑
前端
wuhen_n15 分钟前
RAG 实战:语义检索 + 大模型生成精准问答
前端·langchain·ai编程
沉尘58820 分钟前
ACE-GCM加解密微信小程序
前端
春风得意之时39 分钟前
前端安装项目出现代理问题和ssl认证问题
前端·网络协议·ssl
问心无愧051344 分钟前
ctf show web入门109
android·前端·笔记