网站设计之合理架构CSS
来源:互联网 发布:销售软件的定义 编辑:程序博客网 时间:2024/06/04 18:05
架构CSS
在当前浏览器普遍支持的前提下,css 被我们赋予了前所未有的使命。然而依赖css 越多,样式表文件就会变得越大越复杂。与此同时,文件维护和组织的考验也随之而来。
( 曾几何时) 只要一个css 文件就够了——所有规则(rule) 汇聚一堂,增删改都很方便——可这种日子早已远去。( 现在) 建立新网站时,必须花点时间好好筹划怎么组织和架构css 。
文件的组织
构建css 系统的第一步是大纲的拟定。( 我认为)css 组织规划的重要性堪比网站目录结构。( 注: 用词夸张一点,让你加深记忆) 没有哪种方案放之四海而皆准,因此我们会讨论一些基本的组织方案,以及它们各自的利弊。
主CSS 文件
通常可以使用一个主css 文件,来放置所有页面共享的规则。这个文件会包含默认的字体、链接、页眉和其他等样式。有了主css 文件之后,我们开始探讨高级组织策略。
方法一: 基于原型
最基本的策略是基于原型页面(archetype page) 分离css 文件。假如一个网站的首页、子页面和组合页设计不同,就可以采用基于原型的策略。( 这种策略下) 每个页面都会有专属的css 文件。
在原型数量不多的情况下,这个方法简单明了、行之有效。然而,当页面元素并不按部就班的位于各个原型页时,问题就出现了。如果子页面和组合页共享某些元素,而首页却没有,我们应该怎么做呢?
把共享元素放入主css 文件。这虽不是最纯正的解决办法,却适用于某些具体情况。可是如果网站庞大,( 这样做的话) 主css 文件会迅速膨胀——这就违背了分离文件的初衷: 避免导入不必要的大文件。
在组合页和子页面的css 文件里各放一份样式代码。( 这么做) 就意味着要维护冗余代码,很显然我们不想这样。
创建一个新的文件,由这两种页面共享。这听起来不错。不过假如只有10 行代码,我们创建这个文件仅仅是为了共享这10 行代码?( 注: 杀鸡用牛刀?) 这方法很纯粹,但如果网站庞大有很多对页面共享很少量元素时( 注: 比如30 对页面分别共享10 行代码) ,就显得很笨重了。
创建一个单独的css 文件,包含所有共享元素的样式。这方法可能比较简单,却要取决于网站的大小和共享元素的多少。有种情况会很烦: 导入了一个很大的css 文件,但页面只用到一小部分样式——还是那句话,这违背了分离文件的初衷。
这就是我所说的重叠的两难(overlap dilemma) 。零碎css 规则的重叠不一而足,并没有一个完全清晰无误的方案来组织它们。
方法二: 基于页面元素/ 块
如果网站使用服务器端include ,这个方法会很不错。举例说明,如果使用页眉include ,它会有自己相应的css 文件。页脚或者其他部分的include 可以如法炮制,只须导入自己的css 文件。这个方法简单干净,不过可能会产生很多小css 文件。
举例来说,假如页脚的样式只需要20 行css 代码,单独创建一个文件就划不来了。而且这个方法会导致每个页面都包含一堆css 文件——因为有多少include ,就得有多少css 文件。
方法三: 基于标记
这个方案直观实际,与前一个类似。如果网站共有30 个页面,其中10 个含有form ,那么可以创建一个css 文件专门处理form 的样式,只在这10 个页面导入它。如果另外10 个页面含有table ,就创建一个文件专门处理table 样式……诸如此类。
在当前浏览器普遍支持的前提下,css
(
文件的组织
构建css
主CSS
通常可以使用一个主css
方法一:
最基本的策略是基于原型页面(archetype page)
在原型数量不多的情况下,这个方法简单明了、行之有效。然而,当页面元素并不按部就班的位于各个原型页时,问题就出现了。如果子页面和组合页共享某些元素,而首页却没有,我们应该怎么做呢?
把共享元素放入主css
在组合页和子页面的css
创建一个新的文件,由这两种页面共享。这听起来不错。不过假如只有10
创建一个单独的css
这就是我所说的重叠的两难(overlap dilemma)
方法二:
如果网站使用服务器端include
举例来说,假如页脚的样式只需要20
方法三:
这个方案直观实际,与前一个类似。如果网站共有30
- 网站设计之合理架构css
- 网站设计之合理架构css
- 网站设计之合理架构css
- 网站设计之合理架构CSS
- 网站设计之合理架构css
- 合理架构css
- 合理设计代码架构(设计模式之抽象工厂)
- 网站架构之主页设计
- 网站建设之合理布局
- 读《MySQL性能调优与架构设计》笔记之合理设计并利用索引
- 大型网站架构设计-Solr 网站设计笑话吸收之
- Bootstrap之CSS架构的设计思想
- iOS之03-类的合理设计
- 大型网站架构设计
- 大型网站架构设计
- 著名网站架构设计
- 网站架构设计
- java网站架构设计
- 运行时加载控件!!!
- C++ Primer学习---静态与动态内存发配
- 使用PreparedStatementSetter 设置参数跟 表字段类型不匹配出现的错误
- 整合 Struts 和 Spring
- 将money改变成大写!
- 网站设计之合理架构CSS
- SAP call method
- checkbox的值
- Indicator Variables
- Brew 学习
- Scrollable Cursors
- SAP call BAPI
- 两个Cookie类
- Typical Access Paths