display:none;opacity:0;visibilty:hidden;区别与联系

共同点:他们都会让元素隐藏;
区别:

结构

display:none会让元素完全从渲染树中消失,渲染时不再占据任何空间,不能点击;
visibilty:hidden不会让元素从渲染树上消失,渲染元素继续占据空间,只是内容不可见,不能点击;
opacity:0不会让元素在渲染树中消失,渲染元素继续占据空间,只是内容不可见,可以点击;
继承

display:none和opacity:0:是非继承属性,子孙节点消失由于子元素从渲染树消失造成,通过修改子孙节点属性无法显示;
visibilty:hidden:是继承属性,子孙节点消失由于继承了hidden,通过设置visibilty:visible;可以让子元素节点显示;
继承

1.display:none:修改元素会造成文档回流,读屏器不会读取display:none元素内容,性能消耗较大;

2.visibilty:hidden:修改元素只会造成本元素的重绘,读屏器读取visibilty:hidden元素内容,性能优化较少;

opacity:0:修改元素会造成重绘,性能消耗较少。

前端问题总结 文章被收录于专栏

总结一些前端常见的面试笔试题,来和大家分享鸭

全部评论

相关推荐

码农索隆:想看offer细节
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务