请列举 CSS 中用于隐藏元素的两个属性?两者的差异?
目前,我所知道的不同有三点(欢迎补充):空间占据、回流与渲染、株连性
第一点,想必都知道;
第二点,display:none隐藏产生reflow和repaint(回流与重绘),而visibility:hidden没有这个影响前端性能的问题;
第三点估计是不少同行不知道的,就是“株连性”方面的差异。
所谓“株连性”,就是如果祖先元素遭遇某祸害,则其子子孙孙无一例外也要遭殃。display:none就是“株连性”明显的声明:一旦父节点元素应用了display:none,父节点及其子孙节点元素全部不可见,而且无论其子孙元素如何不屈地挣扎都无济于事。
何时隐藏“失效”?很简单,如果子孙元素应用了visibility:visible,那么这个子孙元素可以显现出来。
对比总结:这两个声明都可以让元素隐藏
display:none;隐藏后的元素不占据任何空间,有株连性,父级设置none,子元素就显示不出来了,回引起渲染与回流,影响性能。
visibility:hidden;隐藏的元素空间依旧存在;伪株连性,父级设计hidden,子元素默认不现实,但是可以用过visibility:visible显示出子元素,无渲染与回流。
更多面试题
如果你想了解更多的前端面试题,可以查看本站的WEB前端面试题 ,这里基本包涵了市场上的所有前端方面的面试题,也有一些大公司的面试图,可以让你面试更加顺利。
面试题 | ||
---|---|---|
HTML | CSS | JavaScript |
jQuery | Vue.js | React |
算法 | HTTP | Babel |
BootStrap | Electron | Gulp |
Node.js | 前端经验相关 | 前端综合 |
Webpack | 微信小程序 | - |
这些题库还在更新中,如果你有不错的面试题库欢迎分享给我,我整理后放上来;人人为我,我为人人,互帮互助,共同提高,祝大家都拿到心仪的Offer!