块级元素有两个基本的特征:独占一行、可以设置宽高。
但是,有些元素还有一些比较特殊的特征,比如 li 还有默认的项目符号。
哎?元素不就是分为块级元素和内联元素吗?那为什么作为块级元素的 li 跟其他的块级元素有所不同呢?
或者这么说,为什么 list-item 元素会出现项目符号呢?这似乎是一个很简单的问题,但是它的背后却有一套体系支撑着,然而,这一切还得从 CSS 的盒子模型说起。
附加盒子
从上面了解到,元素只有两种,一种是块级远古三,另一种是内联元素。那么相应的,在最初的时候,盒子模型也就只有两种,一种是块级盒子,另一种是内联盒子。块级盒子负责结构,内联盒子负责内容。原本以为,块级盒子一套就够用了,也就是说,所有的块级元素用的都是同一个盒子模型,但是,随着需求的改变以及这门语言的发展,派生出一些附加盒子。
所有的块级元素都有一个主块级盒子,但是,list-item 除此以外还有一个附加盒子,具体的学名为 marker box,专门用来存放圆点、数字这些项目符号。
需要注意的是,IE 的伪元素不支持 list-item。
将焦点回到最初的问题上,为什么只有块级元素和内联元素?那么我们一直使用的行内块元素 inline-block 到底是怎么回事?
外在盒子与内在盒子
都知道行内块元素的特性就是介乎于块级元素与内联元素之间,元素可以设置宽高,元素在同一行排列。然而,每个元素都由两个盒子组成,一个是外在盒子,另一个是内在盒子(容器盒子)。外在盒子负责元素是否独占一行,容器盒子负责宽高和内容。
有了上面的这套理论,dipslay:block 的元素实际上就是由一个外在的块级盒子和一个内在的块级盒子组成的。
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
总结一下这三次面试下来我的经验是:
-
一定不要死记硬背,要理解原理,否则面试官一深入就会露馅!
-
代码能力一定要注重,尤其是很多原理性的代码(之前两次让我写过Node中间件,Promise.all,双向绑定原理,被虐的怀疑人生)!
-
尽量从面试官的问题中表现自己知识的深度与广度,让面试官发现你的闪光点!
-
多刷面经!
我把所有遇到的面试题都做了一个整理,并且阅读了很多大牛的博客之后写了解析,免费分享给大家,算是一个感恩回馈吧,有需要的朋友【点击我】免费获取。祝大家早日拿到自己心怡的工作!
篇幅有限,仅展示部分内容
4c863cbcff965.png)