网站规划之合理架构css

2017-01-02    分类: 网站建设

在当时浏览器普遍支撑的前提下,CSS被咱们赋予了史无前例的使命。但是依靠css越多,款式表文件就会变得越大越杂乱。与此同时,文件保护和安排的检测也随之而来。

(曾几何时)只要一个css文件就够了——一切规矩(rule)汇聚一堂,增修改都很便利——可这种日子早已远去。(现在)树立新网站时,有必要花点时刻好好筹划怎样安排和架构css。

文件的安排

构建css系统的第一步是纲要的拟定。(我以为)css安排规划的重要性堪比网站目录结构。(HTMLor注:用词夸大一点,让你加深回忆) 没有哪种计划放之四海而皆准,因此咱们会讨论一些根本的安排计划,以及它们各自的利弊。

主css文件

通常能够运用一个主css文件,来放置一切页面同享的规矩。这个文件会包括默许的字体、链接、页眉和其他等款式。有了主css文件之后,咱们开端讨论高档安排战略。

办法一:依据原型

最根本的战略是依据原型页面(archetype page)别离css文件。假定一个网站的主页、子页面和组合页规划不同,就能够采用依据原型的战略。(这种战略下)每个页面都会有专属的css文件。

在原型数量不多的情况下,这个办法简略明了、行之有效。但是,当页面元素并不墨守成规的位于各个原型页时,问题就出现了。假定子页面和组合页同享某些元素,而主页却没有,咱们应该怎样做呢?

把同享元素放入主css文件。这虽不是最纯粹的解决办法,却适用于某些具体情况。但是假定网站巨大,(这样做的话)主css文件会敏捷膨胀——这就违反了别离文件的初衷:避免导入不必要的大文件。

在组合页和子页面的css文件里各放一份款式代码。(这么做)就意味着要保护冗余代码,很显然咱们不想这样。

创立一个新的文件,由这两种页面同享。这听起来不错。不过假定只要10行代码,咱们创立这个文件只是是为了同享这10行代码?(htmlor 注:杀鸡用牛刀?) 这办法很纯粹,但假定网站巨大有很多对页面同享很少量元素时(htmlor注:比方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文件里的某些规矩可能就得重新考虑。

另外,品牌联合也可能是一个重要因素。(htmlor注:如google和nike联手推出的joga) 假定触及品牌联合,你就得考虑哪些元素应该调整以适应另一品牌。比方别离运用不同的css文件等。

还有一个常被忽略的技巧:运用嵌套的@import句子。只包括一连串@import句子,或许再加几句css规矩,就能创立一个css文件。用这个办法彻底能够创立网站的主css文件(用@import导入各部分的款式文件)。假定网站的每个页面都导入了4到5个不同的css文件,无疑你应该考虑运用这个技巧。

规矩和选择器的安排

谈完了文件安排,接着讨论一下怎样安排文件里的东西吧。很自然,咱们期望在文件里四通八达的浏览,敏捷找到要编辑的选择器(selector)或规矩。

冗余 vs. 隶属

正如Dave Shea在其文章《冗余 vs. 隶属》(Redundancy vs. Dependency)里所说的,你有必要不断了解级联(casCADe)。你要决议是对选择器编组(意味着隶属),仍是把它们别离(意味着冗余)。编组能够坚持代码简洁简明,但是会树立隶属联系,导致保护开销添加。假定不编组,就会添加文件巨细,让类似的选择器坚持一致变得困难。只要做好这种权衡、取舍,才干每次都作出正确的决议。

按相互联系/上下文编组

已然文件安排能够是片面的,那么显然,按照规矩和选择器与其他部分的相互联系来进行编组是最好的办法。举例说明,假定你用容器、页眉和页脚来完成布局,就应该把它们编成一组。

这似乎很简略,其实不然。比方,把页眉中的导航参加CSS时,是将它跟父元素编组仍是独立编组?这种情况下,要视乎规矩的上下文。通常,页眉与页面布局相关,应该与其他布局元素一同编组。而导航是页眉的一块,应该和页眉的其他块编组,而不是页眉自身。

运用注释

跟大多数代码类似,注释是安排良好与否的要害。应该依据css的控制范围,清楚的标示每节(section)。最好确保注释视觉杰出,以便在内容翻滚、一目十行时快速定位。

Doug Bowman在其文章《css安排技巧之一:符号》(CSS Organization Tip #1: Flags)里把css注释玩得高超之极。他详细说明了在节名之前加上等号,以便运用文本编辑器的查找功能敏捷跳到某节。

别忘了

你应该细致仔细的了解了特异性、级联和承继,并善用它们。它们之中的每一项都能够是你最可怕的敌人,也能够是你最友善的朋友。当树立巨大的网站时,是否理解这些细微精妙之处,决议了你所构建的是安如磐石的系统,仍是经不起风雨的豆腐渣工程。(HTMLor注:这句彻底意译,比较爽)

特点的安排

现在咱们了解了文件的安排,也知道了文件内规矩的安排,但还有一个重要的安排环节(没有提到),那便是特点(attribute)。尽管特点比前两个概念更简略,但是还有一些非常好的、能够坚持规矩整齐的办法很值得一提。

按字母排序

提到特点,假定说需求遵循什么原则的话,那便是:按-字-母-排-序。其实这招关于特点浏览协助不大,不过能够防止特点值掩盖这种偶然事情的发作。

举个例子吧,现已数不清有多少次,我为某个选择器界说过了margin值,之后的某天无意间又加了一个(或前或后)。(这种情况下)后一个特点自然会起作用。假定不知道第二个特点存在,不论我怎样调整第一个特点值、改写浏览器,也看不到页面变化。(htmlor注:这个问题我深有体会) 假定按照字母顺序排列,你就会发现margin被界说了两次(由于它们挨在一同),这个问题自然能够避免。

优先项

当网站杂乱、牵涉太多css文件时,会树立很多的隶属联系。一旦需求定制某个元素特有的款式,!important选项似乎是好选择。没错,!important是能解一时之需,但最好搞清楚导致问题的本源,然后依据级联联系决议是否真的需求用它。

假定你对上文提到的特异性、级联和承继很熟悉,大可不必抱着!important一颗树不放。(htmlor注:整片森林等着你~) 当然它仍是会派上用场,不过运用之前要对具体情况了然于胸。千万不要由于不知问题的症结所在而把!important当作捷径或是弥补计划。

小结

当咱们变得依靠css而使款式表日渐杂乱时,就需求正确的计划来避免犯错,并使代码易于保护。已然好无缺的计划并不存在,那么了解css的工作方式以及文件、选择器和特点的多种安排计划,无疑有助于咱们写出优质的代码,饱尝住时刻检测。

名称栏目:网站规划之合理架构css
当前URL:https://www.cdcxhl.com/news/73864.html

成都网站建设公司_创新互联,为您提供虚拟主机品牌网站制作电子商务企业网站制作小程序开发网站策划

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站托管运营