Web前端新人笔记之height、min-height的区别详解

网站建设 2023-01-28 21:38www.1681989.com免费网站

浏览器参照基准Firefox, Chrome, Safari, Opera, IE;  

IE6不支持CSS m-height属性。最小高度的定义1. 元素拥有默认高度;2. 当内容超出元素的默认高度时,元素的高度随内容增加而增加Figure 1:如下图的需求


如上图,两个区域的高度不一样。这就是 m-height 的效果演示。元素拥有一个默认的高度,当内容超出该默认高度时,元素的高度随内容而增加。

CSS Code复制内容到剪贴板
  1. eg1:  
  2. <style>   
  3. .test{   
  4.     float:left;   
  5.     width:200px;   
  6.     marg:0 5px;   
  7.     paddg:10px;   
  8.     border-radius:10px;   
  9.     background:#eee;   
  10. }   
  11. .test{   
  12.     m-height:80px;  / 实现最小高度代码 /  
  13. }   
  14. </style>   
  15.   
  16. <div class="test">喝水为什么会中毒?</div>   
  17. <div class="test">喝水为什么会中毒?<br>日前有媒体报道称日饮用3升水年轻10岁,于是有人真开始喝了,可喝了4天后,尿血了。水是生命之源,不是喝水越多越好呢?喝水多了又会发生什么呢?</div>  

如上代码,我们只需要一行代码 m-height:80px; 就可以实现非IE6浏览器的最小高度。

CSS Code复制内容到剪贴板
  1. .test{   
  2.     height:80px;  / 看看ie6会如何 /  
  3. }  

将 m-height:80px; 改成 height:80px; 在IE6下查看这个样式。你可能发现了奇迹,是的,你没看错。这个DEMO的表现与eg1的demo在高级浏览器下的表现一致,即最小高度的效果。

但这还不是大获全胜的时候,因为你会发现本例在高级浏览器下都GameOver了。肿么办,这不是坑爹么?别着急,作为一个合格的coder,你肯定会想各种办法来搞定它。

你是一个前端工程师,所以你必须要知道一些浏览器专属的CSS Hack,虽然大多数情况下不推荐使用。我们想办法让高级浏览器仍然使用m-height,而ie6使用height,这样似乎就可以达成目的了,动手吧。

 

CSS Code复制内容到剪贴板
  1. Figure 4:大获全胜的场景.test{   
  2.     m-height:80px;  / for ie7+, firefox, chrome, safari, opera /  
  3.     _height:80px;        / for ie6 /  
  4. }  

ok, 我们实现了包含ie6在内的m-height效果。

记住,千万别加overflow除visible之外的值,否则你的ie6又要悲剧demo

以上这篇Web前端新人笔记之height、m-height的区别详解就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。

原文地址

Copyright © 2016-2025 www.1681989.com 推火网 版权所有 Power by