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

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

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; 只是让这个人隐身,实际上他还在,后面的人不能往前动。

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

相关推荐
尘世中一位迷途小书童1 分钟前
一套完整的给予ceium封装的组件库,可满足企业级开发
前端
Z_Wonderful2 分钟前
微前端:Webpack 配置 vs Vite 配置 超清晰对比
前端·webpack·node.js
码云数智-园园7 分钟前
HTTPS是如何工作的?从HTTP到HTTPS的加密演进
前端
隔窗听雨眠15 分钟前
HTML头部元信息避坑指南
前端·html
Gauss松鼠会23 分钟前
【openGauss】openGauss 磁盘引擎之 ustore
java·服务器·开发语言·前端·数据库·经验分享·gaussdb
LIO24 分钟前
前端响应式页面开发全攻略:核心技术 + 实现效果 + 实战指南
前端·响应式设计
得物技术39 分钟前
AI驱动:从运营行为到自动化用例的智能化实践|得物技术
前端·ai编程·全栈
前端那点事40 分钟前
Vue并发控制|几十个请求高效管控(实战方案+可运行代码)
前端·vue.js
妄想出头的工业炼药师44 分钟前
后端优化MS mapping
前端
前端那点事1 小时前
Vue大批量接口请求优化|告别卡顿、超时!前端落地实战指南
前端·vue.js