zoukankan      html  css  js  c++  java
  • 如何处理上下margin

    如何处理上下margin

         对于模块来说,其上下margin不确定,因为美术设计的需求不同,可能同样样式的模块,在不同位置上有不同的上下margin。如图1所示。
     
    简单示意图图1


     

        图2中用线框出的部分有相同的样式、字号、颜色,且都有下划线。很明显,我们可以将它提取成一个通用的组件。如代码清单1所示。
    简单示意图中样式相同的模块图2
     代码清单1     提取标题组件
     
    1. <style type="text/CSS"> 
    2. .title{border-bottom:1px dashed #B2BCC6;color:#0066CF;font- size: 16px; font-weight:bold;)  
    3. </style> 
    4. <h2 class="title">服务理念</h2> 
    5. <h2 class="title">服务宗旨</h2> 
    6. <h2 class="title">产品的优势</h2> 
        这些样式相同的模块还有上下margin,我们应该如何设置它们的上下margin呢?提取组件时,需要将上下margin也包含进来吗?
     
     
        需要按图3所示重新提取组件吗?可是这三个模块的margin-top并不相同,如图4所示。
     
    包含上下margin的模块图3


     

    模块的margin-top不同图4 
     
     
     如果组件需包含margin值,那么其代码如代码清单2所示。
    1. <style type="text/CSS"> 
    2.  .titlel{
    3. border-bottom:1px dashed #B2BCC6;color:#0066CF;font-size:16px; 
    4. font-weight :bold;margin-top: 20px; }  
    5.  .title2{
    6. border-bottom:1px dashed #B2BCC6;color:#0066CF;font-size:16px; 
    7. font-weight :bold;margin-top: 60px; }  
    8. </style> 
    9. <h2 class="title1">服务理念</h2 > 
    10.            ...  
    11. <h2 class="titlel">服务宗旨</h2> 
    12.            ...  
    13. <h2 class="title2">产品优势</h2> 
     
     
        如果又出现一个新的设计,需要改变margin-top值,我们需要再定义title3和title4 吗?包含margin这个不稳定样式到组件里,大大限制了类的重用性!如果再多设计几个margin值不同的模块,很容易产生类数量的人爆炸。这就是我们上节讲到过的“多用组合,少用继承”,解决这个问题的方法就是将类中不稳定的部分分离出来,单独设置成一个类,将相对稳定的剩下的那部分设置成另一个类,通过类的组合——挂多个class实现最终样式。 模块的上下margin是类的组合的一个典型应用。应用类的组合如代码清单3所示。
     
     
        代码清单3    应用类的组合   
    1. <style type="text/CSS"> 
    2.  .mt20{margin-top:20px;)  
    3.  .mt60(margin-top:60px;}  
    4.  .title{border-bottom:1px dashed #B2BCC6;color:#0066CF;font-size:16px; font-weight:bold;}  
    5. </style> 
    6. <h2 class="title mt20">服务理念</h2> 
    7.     ...  
    8. <h2 class="title mt20">服务宗旨</h2> 
    9.         ...  
    10. <h2 class="title mt60">产品优势</h2> 
    11.       ...  
     
     
     
        除了给图中所示模块挂上margin-top的类,其实也可以给别的模块挂卜margin-bottom的类,如图5所示。


    给其他模块加margin-bottom 图5

     
     
     
     
    还有些工程师会采取如图6所示的添加方法。
     

    margin-top和margin-bottom混用图6
     

     
     
        图6混用了margin-top和margin-bottom,但事实上,这种做法会带来意外的效果——上下margin重合问题。margin是个有点特殊的样式,相邻的margin-left和margin-right是不会重合的,但相邻的margin-top和margin-bottom会产生重合。图6的真实效果如图7所示。
    margin-top和margin-bottom重合 图7
     
        如果对相邻的模块同时使用了margin-top和margin-bottom,边距会重合带来不必要的麻烦,所以最好统一使用margin-top或者margin-bottom,不要混合使用,从而降低出现问题的风险。这并不是技术上必需的,但却是一个良好的习惯。
     
     
     
        总结:如果不确定模块的上下margin特别稳定,最好不要将它写到模块的类里,而是使用类的组合,单独为上下margin挂用于边距的原子类(例如mr10、mb20)。模块最好不要混用margin-top和margin-bottom,统一使用margin-top或margin-bottom
  • 相关阅读:
    用简单C程序分析DOS下的EXE文件【转】
    汇编函数的调用[转自KingofCoders]
    windows下的shellcode剖析浅谈[转自看雪]
    如何写一个简单的病毒程序[转]
    不用注册访问论坛技巧
    函数调用堆栈变化分析[转自看雪]
    IT学生解惑真经(下载)
    Windows 汇编语言编程教程[转]
    ESP定律介绍(转自看雪论坛贴)
    【Anti Virus专题】1.1 病毒的原理 [转自看雪]
  • 原文地址:https://www.cnblogs.com/csdttnk/p/2848395.html
Copyright © 2011-2022 走看看