CSS中height和min-height的区别

(编辑:jimmy 日期: 2024/12/24 浏览:2)

做为Web前端新人,需要了解height、min-height的区别

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

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

Figure 1:如下图的需求

CSS中height和min-height的区别

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

eg1:

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

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

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

CSS中height和min-height的区别

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

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

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

 CSS中height和min-height的区别

Figure 4:大获全胜的场景

CSS Code复制内容到剪贴板
  1. .test{   
  2.     min-height:80px;  /* for ie7+, firefox, chrome, safari, opera */  
  3.     _height:80px;        /* for ie6 */  
  4. }   
  5.   

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

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

以上就是本文的全部内容,希望对大家的学习有所帮助。

一句话新闻

一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?