• CSS:CSS 在工程中改变——面向对象的CSS (OO CSS)


    一、OO  CSS 的概念解读

    (一)众多开发者忽视了CSS的表现,认为其太过简单,是一种机械的工作,而把更多关注在JS的性能或者其他方面。

    (二)OO CSS 将页面可重用元素抽象成一个类,用class 加以描述,而与其对应的html 即可看成是此类的一个实例。

    二、OO CSS 的作用

    (一)加强代码复用以便方面维护。

    (二)减少 CSS 体积(用父类的即可)。

    (三)提升渲染效率。

    (四)组件库思想、栅格布局可共同、减少选择器、方面扩展。

    三、OO CSS 的注意事项(使用高效CSS时需要注意的问题)

    (一)不要直接定义子节点,应把共性声明放到父类。

    .mod .inner {...}    // .mod 下面的 inner
    .inner {...}    // 不是很建议的声明

    (二)结构与皮肤相分离。

    <div class="container simpleExt"></div>  //html 结构
        .container {...}  //控制结构的class
        .simpleExt {...}  //控制皮肤的class

    (三)容器与内容相分离。

    <div class="container"><ul><li>排行</li></ul></div> //html 结构
       .container ul{...}  //ul依赖了容器
    <div class="container"><ul class="rankList"><li>排行</li></ul></div> //html 结构
       .rankList ul{...}  //解除与容器的依赖,可以从一个容器转移到其他容器

    (四)抽象出可重用的元素,建好组件库,在组件库内寻找可用的元素组装页面。

    (五)往你想要扩展的对象本身增加 class 而不是其父节点。

    (六)对象应该保持独立性

    <div class="container"><div class="mod"></div></div> //html 结构
          .container {...}  
          .container .mod {...} //控制结构的class
       //应该写成如下:
       <div class="container mod"> </div> //html 结构

    (七)避免使用ID选择器,权重太高,无法重用。

    (八)避免位置相关的样式

    #header .container {...}
     #footer .container {...}
    //可直接写成 .container {...}
       
       #header h1 {...}
       #footer h1 {...}
       h1,.h1 { }
       h2,.h2 { }
       <h1 class="h6"></h1>

    (九)保证选择器相同的权重

    (八)类名应该剪短、清晰、语义化,OO CSS 的名字并不影响html 语义化

  • 相关阅读:
    HDU 6194【后缀数组】
    SGU 104 Little shop of flowers【DP】
    POJ 2104 K-th Number【整体二分 + 树状数组】
    HDU 5573 Binary Tree【构造】
    UVA 10245 The Closest Pair Problem【分治】
    POJ 1741 Tree【树分治】
    边缘检测的微分算子简单比较【1】
    HDU 5584 LCM Walk【搜索】
    51nod 1686 第K大区间【离散化+二分】
    HDU 5572 An Easy Physics Problem【计算几何】
  • 原文地址:https://www.cnblogs.com/shenxiaolin/p/5388662.html
Copyright © 2020-2023  润新知