<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>第8音 PD  ID  UE &#187; css</title>
	<atom:link href="http://blog.d8in.com/posts/tag/css/feed" rel="self" type="application/rss+xml" />
	<link>http://blog.d8in.com</link>
	<description>Design is a  Life Style</description>
	<lastBuildDate>Wed, 10 Mar 2010 12:44:03 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>xStyle alpha 1.0 发布</title>
		<link>http://blog.d8in.com/posts/178.html</link>
		<comments>http://blog.d8in.com/posts/178.html#comments</comments>
		<pubDate>Sun, 30 Dec 2007 11:43:04 +0000</pubDate>
		<dc:creator>xw</dc:creator>
				<category><![CDATA[产品编码]]></category>
		<category><![CDATA[css]]></category>
		<category><![CDATA[framework]]></category>

		<guid isPermaLink="false">http://blog.d8in.com/posts/178.html</guid>
		<description><![CDATA[
  xStyle 是一个非常简单的 css framwork,如果您是一名css老手那么简单看一下代码就可以立即用用到您的项目开发中去，即使是新手也只需要话5分钟看一下cheat sheet 即可使用，如果看了cheat sheet您都不会用的话,哪您最好找一本css入门教程看一下了。 
   xStyle的特点：
   1、页面松耦合：xStyle 和其它css framework的最大的最大区别就是，完全和页面的结构没有关系，或者说是特别轻的相关性，大多数的属性都是一次性定义一个html元素即可。
   2、从新定义和封装：xStyle中封装了许多css现有的属性，譬如margin padding font 这些，从表面上来说是降低了灵活性，但是在实际项目开发中却提高了代码重用度和统一性，而且当程序员问你这里的要用什么字体颜色，什么样的边距的时候，你只需要告诉他加上一个xxxclass就行啦。
   3、快速部署：xStyle中包含了css项目开发中最常用的定义方法和一些小工具，您只需要稍微修改一下就可以快速的应用到你的项目开发中去。
   4、良好的扩展性：xStyle不仅仅是一个css framework，更是一种高效快速css开发方式，里面的代码您可以按照里面的方式自己进行随意更改和补充，然后修改成你公司或你自己的css framework。
 
   xStyle现在还是一个很简单的版本，由于时间仓促还有很多不足，如果有什么bug和意见希望大家通过 xwxwxw[at]gmail.com 与我联系。
下载地址：http://xstyle.d8in.com
]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.flickr.com/photos/xwxw/2150271727/" title="xstyle by xwgemini, on Flickr"><img src="http://farm3.static.flickr.com/2090/2150271727_7e30e2bd51_o.jpg" width="380" height="90" alt="xstyle" /></a></p>
<p>  xStyle 是一个非常简单的 css framwork,如果您是一名css老手那么简单看一下代码就可以立即用用到您的项目开发中去，即使是新手也只需要话5分钟看一下cheat sheet 即可使用，如果看了cheat sheet您都不会用的话,哪您最好找一本css入门教程看一下了。 </p>
<p>   <strong>xStyle的特点：</strong><br />
   1、页面松耦合：xStyle 和其它css framework的最大的最大区别就是，完全和页面的结构没有关系，或者说是特别轻的相关性，大多数的属性都是一次性定义一个html元素即可。</p>
<p>   2、从新定义和封装：xStyle中封装了许多css现有的属性，譬如margin padding font 这些，从表面上来说是降低了灵活性，但是在实际项目开发中却提高了代码重用度和统一性，而且当程序员问你这里的要用什么字体颜色，什么样的边距的时候，你只需要告诉他加上一个xxxclass就行啦。</p>
<p>   3、快速部署：xStyle中包含了css项目开发中最常用的定义方法和一些小工具，您只需要稍微修改一下就可以快速的应用到你的项目开发中去。</p>
<p>   4、良好的扩展性：xStyle不仅仅是一个css framework，更是一种高效快速css开发方式，里面的代码您可以按照里面的方式自己进行随意更改和补充，然后修改成你公司或你自己的css framework。<br />
 <br />
   xStyle现在还是一个很简单的版本，由于时间仓促还有很多不足，如果有什么bug和意见希望大家通过 xwxwxw[at]gmail.com 与我联系。</p>
<p>下载地址：<a href="http://xstyle.d8in.com">http://xstyle.d8in.com</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.d8in.com/posts/178.html/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>收集的一些css framework</title>
		<link>http://blog.d8in.com/posts/177.html</link>
		<comments>http://blog.d8in.com/posts/177.html#comments</comments>
		<pubDate>Tue, 25 Dec 2007 10:35:54 +0000</pubDate>
		<dc:creator>xw</dc:creator>
				<category><![CDATA[产品编码]]></category>
		<category><![CDATA[css]]></category>
		<category><![CDATA[framework]]></category>

		<guid isPermaLink="false">http://blog.d8in.com/posts/177.html</guid>
		<description><![CDATA[
YUI CSS库
http://developer.yahoo.com/yui/
YAML（Yet Another Multicolumn Layout）
http://www.yaml.de/en/ 
Content with Style: A CSS Framework
http://www.contentwithstyle.co.uk/Articles/17/
Blueprint
http://code.google.com/p/blueprintcss/
tripoli
http://monc.se/tripoli/
Elements
http://elements.projectdesigns.org/index.html
WYMstyle: a CSS framework
http://www.wymstyle.org/en/
taffy-css-framework
http://code.google.com/p/taffy-css-framework/
]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.flickr.com/photos/xwxw/2137215264/" title="css Framework by xwgemini, on Flickr"><img src="http://farm3.static.flickr.com/2163/2137215264_9d719d9f9a_m.jpg" width="240" height="160" alt="css Framework" /></a></p>
<p><strong>YUI CSS库</strong><br />
<a href="http://developer.yahoo.com/yui/">http://developer.yahoo.com/yui/</a></p>
<p><strong>YAML（Yet Another Multicolumn Layout）</strong><br />
<a href="http://www.yaml.de/en/ ">http://www.yaml.de/en/ </a></p>
<p><strong>Content with Style: A CSS Framework</strong><br />
<a href="http://www.contentwithstyle.co.uk/Articles/17/ ">http://www.contentwithstyle.co.uk/Articles/17/</a></p>
<p><strong>Blueprint</strong><br />
<a href="http://code.google.com/p/blueprintcss/">http://code.google.com/p/blueprintcss/</a></p>
<p><strong>tripoli</strong><br />
<a href="http://monc.se/tripoli/">http://monc.se/tripoli/</a></p>
<p><strong>Elements</strong><br />
<a href="http://elements.projectdesigns.org/index.html">http://elements.projectdesigns.org/index.html</a></p>
<p><strong>WYMstyle: a CSS framework</strong><br />
<a href="http://www.wymstyle.org/en/">http://www.wymstyle.org/en/</a></p>
<p><strong>taffy-css-framework</strong><br />
<a href="http://code.google.com/p/taffy-css-framework/">http://code.google.com/p/taffy-css-framework/</a></p>
]]></content:encoded>
			<wfw:commentRss>http://blog.d8in.com/posts/177.html/feed</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>理解Web框架，和如何构建一个CSS框架[转][译]</title>
		<link>http://blog.d8in.com/posts/176.html</link>
		<comments>http://blog.d8in.com/posts/176.html#comments</comments>
		<pubDate>Mon, 24 Dec 2007 09:54:26 +0000</pubDate>
		<dc:creator>xw</dc:creator>
				<category><![CDATA[产品编码]]></category>
		<category><![CDATA[css]]></category>
		<category><![CDATA[framework]]></category>

		<guid isPermaLink="false">http://blog.d8in.com/posts/176.html</guid>
		<description><![CDATA[

去年在网上看了这篇文章是英文的，最近找一些资料发现有人已经翻译成中文了，特此拿来给大家分享

近来，在Web开发中”框架”是一个相当时髦的词。比如JavaScript 框架 YUI、 JQuery和Prototype 都引起广泛的关注， Web应用框架Rails and Dojo 更是引人瞩目，仿佛所有人都使用某种框架来开发自己的网站。但究竟什么是框架?是不是框架仅仅是对程序员有用，设计师是否可以从中收益？
什么是框架?
为了便于沟通，我们给“框架”统一一个定义（至少在本篇文章中是统一的）：一套包含工具、函数库、约定，以及尝试从常用任务中抽象出可以复用的通用模块，目标是使设计师和开发人员把重点放在任务项目所特有的方面，避免重复开发。通常的讲，框架就是上面提到的JavaScript框架和Web应用框架。
需要强调说明的是，我们不必讨论构造、打包发布，相反，一个框架只为你或你的团队使用即可。

CSS框架
有些时候，你可能尝到了抽象类似的CSS代码的甜头，在那些同时设计几个类似网站的设计师身上表现最为明显。此外，团队中的设计师们从框架的方法上有很多的获益。比如，我在一家报馆工作，所有的20多个网站保持着很多的共同点，基于新闻网站的特点，它们趋向于更加相似，而不是差异。但是，即使单独一个设计师，设计一个从表面上看有差异很大的项目，也可以为CSS框架抽象出一些通用的小碎片。
劳伦斯日报（Lawrence Journal-World），我在那里工作，我们最近建立了一个CSS框架，并发现它是一个巨大的效率倍增。当然，我们花了数天时间自己创建了一个 CSS框架，但一旦框架完工，开发高质量网页的速度是极快的。更何况，既然团队每一个设计师现在都使用这个框架，当一个设计师修改另一个团队成员网页时，他们不再需要花20分钟理解别人的构建思路，可以马上上手。
有那些可以忽略?
当投入到一个整体性很强的CSS框架，你想寻找的东西，是每个项目都做了一遍又一遍的重复通用的代码，目标是巩固这些代码核心地位，遵循“不重复自己（Don’t Repeat Yourself）”编码方法。这使得维护工作容易了许多，还可以帮访问者节省带宽开销。
几乎每个我参与的项目中，我必须声明的几个CSS问题：
“大量重置”浏览器默认风格，比如，设置所有元素的margin和padding为0，去掉框架（framesets）和图片（images）的border，等等。
以基线对齐。这包括诸如设定块级元素的margins相同的(或多个)基准行高，如段落（paragraph）、头（header）、以及列表（list）。
创建表单（Form）的基本样式。
创建几个常用的CSS 类，例如，.hide(把display置为none，即隐藏元素)、.mute(设定为一个较小的字体和较亮的颜色)。
还有更有趣的事情，许多网站设计师发现自己不断重复使用着相同的基本结构，为什么不动它整理成自己的，在某种程度上可以非常灵活的用于多个网站? Yahoo这样做了，这就是YUI。当我们为的劳伦斯日报网站（the Journal-World）建立CSS框架的时候，我先看看Yahoo是怎么做的。我们很肯定那不是我们想要的，但作为一个很好的例子，给我们提供了很多思考和如何建构自己框架的想法。我们解决了16个单元格的问题，它具有足够的灵活性使我们的每一个网站都可以应用，即使每个网站看上去与下一个版本有些差异。另外大多数网站共用widgets ，象下拉菜单、导航菜单、按钮等，这些也是主要的需要抽象提取的对象。除此之外,你可能有共同的内容名称，如图片列表的缩略图，你可以规范对CSS命名，如“thumbnail-list”，让所有显示缩略图的都使用这个CSS类。
另外要做的可能是抽取hack（如兼容那些旧浏览器)加入自己的扩展的样式模块。我自己尝试过，但发现hack过于专有而不能抽取到通用框架里。
什么是真正的益处?
框架的真正好处是能够快速启动工作，你可以创建一个新的(X)HMTL文件，引入你框架，你不用再处理重置padding 和 margins的事情，漂亮的排版，干净的表单，整齐的布局，有效的widgets，等等。很明显，很明显，虽然，你一定要来定制外观和感觉为每个站点。为实现这一目标,所有你需要做的是复写,并添加到默认的风格是必要的。
很显然，尽管你必须为每个网站定制外观，为了完成这一任务，你所需要做的就是在默认的样式上加几行代码。举个例子，如果在你的框架里，为所有的 class属性为“tabs”的UL标签设置了基本的水平导航样式，并且有一个灰色的边框，你只需要几行CSS代码，就可以定制成你的网站所符合的外观样式。
Example Source Code
ul.tabs li {
border:&#160;none;
background-image: url(’/images/tabs/site-specific-tab-look.jpg’);
}
列表左浮动，并且将链接以块的形式置于列表当中，链接也左浮动，字体居中，象烦人的广告一样的这些工作，框架以帮你完成，在你的网站设计工作中，只需集中精力处理特别的、有趣的网站细节，而不是写已经写过百万次的CSS代码。
如何构建一个CSS框架?
构建一个框架有几种可能的方式，但最常见，可以说是最有用的，抽象通用的CSS放到一个独立样式表文件，该样式表文件只包含整体的一个特有部分。例如,你可以，一个样式处理排版，另一个处理大量重置。这种好的方法能使你选择性引入你需要的样式，在你框架里可能有六七个不同的样式文件，但不需要其中的一两个，只要不引入即可。我们团队创建的框架包含5个样式文件：
reset.css —处理重置
type.css —处理排版
grid.css —处理布局
widgets.css —处理小零件（widgets），如tab菜单、下拉菜单、以及“更多”按钮
base.css —包含所有的其他样式表文件，以便我们只需要在(X)HTML引用base.css即可使用整个CSS框架
然后，我们把框架存放在一个单独的地方，使每一个站点都引入这个框架。当然，每一个网站也需要有特有样式表，特有样式对框架进行了必要的补充。
忠告
这种方法不错,但也带来新的问题：增加了每一个页面的http链接数。对于大流量和中等流量的网站，每个页面增加5个以上HTTP连接数，系统管理员可能就麻烦大了。两个可能解决办法：
把所有样式都放到一个文件里，而不是分成多个模块。这里的问题是，失去了框架只包含特定文件的灵活性，而且维护也变得麻烦。
有一个服务器端程序,动态把多个单个文件处理成一个响应。我还没看到这种做法，但如果做好了应该是很有效率的。以我上面框架为例，当请求（Request）base.css时候，而不是请求（Request）type.css , grids.css 等的时候，这一动态处理过程触发。这样一来,单个文件仍然可用，而在平台版本上整个框架也有效的。
总之，我们目标不是尽可能的抽象，这点非常重要。相反,其目标是提供了一个快速启动和更有效率的设计过程，这是绝对有可能去做过的。如果你过于的抽象，事情会变得混乱，太多的HTTP链接数会影响你网站的性能。记住：一个好的框架不是把事情搞更难更复杂，而是一个简单的从零的开始。
总结
我们web设计师往往经常重复自己，就像我程序世界里的那些朋友，我们重置浏览器默认样式、设计布局和导航菜单写了一遍又一遍——几乎每个项目。花一点时间整理CSS 框架，可以使你快速的启动每一个网站项目，更轻松的维护网站，并帮助团队里其他的设计师理解你作品。要注意的一点，这些益处的获得必须以不影响网站的性能为前提。 
]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.flickr.com/photos/xwxw/2134644808/" title="framework by xwgemini, on Flickr"><img src="http://farm3.static.flickr.com/2141/2134644808_994781ce6f_m.jpg" width="240" height="98" alt="framework" /></a></p>
<blockquote><p>
去年在网上看了这篇文章是英文的，最近找一些资料发现有人已经翻译成中文了，特此拿来给大家分享
</p></blockquote>
<p>近来，在Web开发中”框架”是一个相当时髦的词。比如JavaScript 框架 YUI、 JQuery和Prototype 都引起广泛的关注， Web应用框架Rails and Dojo 更是引人瞩目，仿佛所有人都使用某种框架来开发自己的网站。但究竟什么是框架?是不是框架仅仅是对程序员有用，设计师是否可以从中收益？</p>
<p><strong>什么是框架?</strong></p>
<p>为了便于沟通，我们给“框架”统一一个定义（至少在本篇文章中是统一的）：一套包含工具、函数库、约定，以及尝试从常用任务中抽象出可以复用的通用模块，目标是使设计师和开发人员把重点放在任务项目所特有的方面，避免重复开发。通常的讲，框架就是上面提到的JavaScript框架和Web应用框架。</p>
<p>需要强调说明的是，我们不必讨论构造、打包发布，相反，一个框架只为你或你的团队使用即可。<br />
<span id="more-176"></span><br />
<strong>CSS框架</strong></p>
<p>有些时候，你可能尝到了抽象类似的CSS代码的甜头，在那些同时设计几个类似网站的设计师身上表现最为明显。此外，团队中的设计师们从框架的方法上有很多的获益。比如，我在一家报馆工作，所有的20多个网站保持着很多的共同点，基于新闻网站的特点，它们趋向于更加相似，而不是差异。但是，即使单独一个设计师，设计一个从表面上看有差异很大的项目，也可以为CSS框架抽象出一些通用的小碎片。</p>
<p>劳伦斯日报（Lawrence Journal-World），我在那里工作，我们最近建立了一个CSS框架，并发现它是一个巨大的效率倍增。当然，我们花了数天时间自己创建了一个 CSS框架，但一旦框架完工，开发高质量网页的速度是极快的。更何况，既然团队每一个设计师现在都使用这个框架，当一个设计师修改另一个团队成员网页时，他们不再需要花20分钟理解别人的构建思路，可以马上上手。</p>
<p><strong>有那些可以忽略?</strong></p>
<p>当投入到一个整体性很强的CSS框架，你想寻找的东西，是每个项目都做了一遍又一遍的重复通用的代码，目标是巩固这些代码核心地位，遵循“不重复自己（Don’t Repeat Yourself）”编码方法。这使得维护工作容易了许多，还可以帮访问者节省带宽开销。</p>
<p><strong>几乎每个我参与的项目中，我必须声明的几个CSS问题：</strong></p>
<p>“大量重置”浏览器默认风格，比如，设置所有元素的margin和padding为0，去掉框架（framesets）和图片（images）的border，等等。<br />
以基线对齐。这包括诸如设定块级元素的margins相同的(或多个)基准行高，如段落（paragraph）、头（header）、以及列表（list）。<br />
创建表单（Form）的基本样式。<br />
创建几个常用的CSS 类，例如，.hide(把display置为none，即隐藏元素)、.mute(设定为一个较小的字体和较亮的颜色)。<br />
还有更有趣的事情，许多网站设计师发现自己不断重复使用着相同的基本结构，为什么不动它整理成自己的，在某种程度上可以非常灵活的用于多个网站? Yahoo这样做了，这就是YUI。当我们为的劳伦斯日报网站（the Journal-World）建立CSS框架的时候，我先看看Yahoo是怎么做的。我们很肯定那不是我们想要的，但作为一个很好的例子，给我们提供了很多思考和如何建构自己框架的想法。我们解决了16个单元格的问题，它具有足够的灵活性使我们的每一个网站都可以应用，即使每个网站看上去与下一个版本有些差异。另外大多数网站共用widgets ，象下拉菜单、导航菜单、按钮等，这些也是主要的需要抽象提取的对象。除此之外,你可能有共同的内容名称，如图片列表的缩略图，你可以规范对CSS命名，如“thumbnail-list”，让所有显示缩略图的都使用这个CSS类。</p>
<p>另外要做的可能是抽取hack（如兼容那些旧浏览器)加入自己的扩展的样式模块。我自己尝试过，但发现hack过于专有而不能抽取到通用框架里。</p>
<p><strong>什么是真正的益处?</strong></p>
<p>框架的真正好处是能够快速启动工作，你可以创建一个新的(X)HMTL文件，引入你框架，你不用再处理重置padding 和 margins的事情，漂亮的排版，干净的表单，整齐的布局，有效的widgets，等等。很明显，很明显，虽然，你一定要来定制外观和感觉为每个站点。为实现这一目标,所有你需要做的是复写,并添加到默认的风格是必要的。</p>
<p>很显然，尽管你必须为每个网站定制外观，为了完成这一任务，你所需要做的就是在默认的样式上加几行代码。举个例子，如果在你的框架里，为所有的 class属性为“tabs”的UL标签设置了基本的水平导航样式，并且有一个灰色的边框，你只需要几行CSS代码，就可以定制成你的网站所符合的外观样式。</p>
<p>Example Source Code</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Blue;">ul.tabs</span><span style="color: Gray;"> </span><span style="color: Blue;">li</span><span style="color: Gray;"> </span><span style="color: Olive;">{</span></li>
<li><span style="color: Green;">border:</span><span style="color: Gray;">&nbsp;</span><span style="color: Red;">none</span><span style="color: Gray;">;</span></li>
<li><span style="color: Green;">background-image:</span><span style="color: Gray;"> url(’/images/tabs/site-specific-tab-look.jpg’)</span><span style="color: Gray;">;</span></li>
<li><span style="color: Olive;">}</span></li></ol></div>
<p>列表左浮动，并且将链接以块的形式置于列表当中，链接也左浮动，字体居中，象烦人的广告一样的这些工作，框架以帮你完成，在你的网站设计工作中，只需集中精力处理特别的、有趣的网站细节，而不是写已经写过百万次的CSS代码。</p>
<p><strong>如何构建一个CSS框架?</strong></p>
<p>构建一个框架有几种可能的方式，但最常见，可以说是最有用的，抽象通用的CSS放到一个独立样式表文件，该样式表文件只包含整体的一个特有部分。例如,你可以，一个样式处理排版，另一个处理大量重置。这种好的方法能使你选择性引入你需要的样式，在你框架里可能有六七个不同的样式文件，但不需要其中的一两个，只要不引入即可。我们团队创建的框架包含5个样式文件：</p>
<p>reset.css —处理重置<br />
type.css —处理排版<br />
grid.css —处理布局<br />
widgets.css —处理小零件（widgets），如tab菜单、下拉菜单、以及“更多”按钮<br />
base.css —包含所有的其他样式表文件，以便我们只需要在(X)HTML引用base.css即可使用整个CSS框架<br />
然后，我们把框架存放在一个单独的地方，使每一个站点都引入这个框架。当然，每一个网站也需要有特有样式表，特有样式对框架进行了必要的补充。</p>
<p><strong>忠告</strong></p>
<p>这种方法不错,但也带来新的问题：增加了每一个页面的http链接数。对于大流量和中等流量的网站，每个页面增加5个以上HTTP连接数，系统管理员可能就麻烦大了。两个可能解决办法：</p>
<p>把所有样式都放到一个文件里，而不是分成多个模块。这里的问题是，失去了框架只包含特定文件的灵活性，而且维护也变得麻烦。<br />
有一个服务器端程序,动态把多个单个文件处理成一个响应。我还没看到这种做法，但如果做好了应该是很有效率的。以我上面框架为例，当请求（Request）base.css时候，而不是请求（Request）type.css , grids.css 等的时候，这一动态处理过程触发。这样一来,单个文件仍然可用，而在平台版本上整个框架也有效的。<br />
总之，我们目标不是尽可能的抽象，这点非常重要。相反,其目标是提供了一个快速启动和更有效率的设计过程，这是绝对有可能去做过的。如果你过于的抽象，事情会变得混乱，太多的HTTP链接数会影响你网站的性能。记住：一个好的框架不是把事情搞更难更复杂，而是一个简单的从零的开始。</p>
<p><strong>总结</strong></p>
<p>我们web设计师往往经常重复自己，就像我程序世界里的那些朋友，我们重置浏览器默认样式、设计布局和导航菜单写了一遍又一遍——几乎每个项目。花一点时间整理CSS 框架，可以使你快速的启动每一个网站项目，更轻松的维护网站，并帮助团队里其他的设计师理解你作品。要注意的一点，这些益处的获得必须以不影响网站的性能为前提。 </p>
]]></content:encoded>
			<wfw:commentRss>http://blog.d8in.com/posts/176.html/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>“少用继承，多用组合”之CSS篇</title>
		<link>http://blog.d8in.com/posts/171.html</link>
		<comments>http://blog.d8in.com/posts/171.html#comments</comments>
		<pubDate>Mon, 05 Nov 2007 22:43:52 +0000</pubDate>
		<dc:creator>xw</dc:creator>
				<category><![CDATA[产品编码]]></category>
		<category><![CDATA[css]]></category>

		<guid isPermaLink="false">http://blog.d8in.com/posts/171.html</guid>
		<description><![CDATA[
继承是 css中经常要用到的技术，好处是可以尽量让页面的代码减少重复利用，但是随时项目越来越大，需求的不断变化，css代码就会变得越来越臃肿，后期难以控制和维护。其实，css代码和普通程序代码在编写的时候有很多的相似之处，下面我们就用试试用组合的方式是不是能更好的解决这个问题。
下面是一段普通的代码:
css:
.box{
&#160; border:1px&#160;solid #ccc;
&#160; font-size:12px;
&#160; background:#f1f1f1;
&#160; padding:10px;
}
html：
&#60;div class=&#34;box&#34;&#62;this is&#160; a gray box&#60;/div&#62;

但是这个时候需求增加了，在页面中不仅要有一个灰色的盒子可能还有蓝色的盒子，可能还有绿色，通常我们会说用集成嘛，好我们就做如下更改
css:
.box-gray,
.box-green{
&#160; border:1px&#160;solid #ccc;
&#160; font-size:12px;
&#160; padding:10px;
}
.box-gray{background:#f1f1f1}
.box-green{background:#66ff66}
Html:
&#60;div class=&#34;box-gray&#34;&#62;this is&#160; a gray box&#60;/div&#62;
&#60;div&#160;class=&#34;box-green&#34;&#62;this is a green box&#60;/div&#62;
但是这个时候需求又有变化了，根与应用的不同，盒子中有些要用到12号字，有些要用到14号字，有些要变局10px有些要20px，估计这个时候你就要头大了，如果要用用继承css代码就会变得异常的复杂，那我们就来试验一下用组合的方式看能不能解决。
css:
.fs-12{font-size:12px}
.fs-14{font-size:14px}
.pd-10{padding:10px}
.pd-20{padding:20px}
&#160;
.box{
&#160; border:1px&#160;solid #ccc;
}
.box.gray{background:#f1f1f1}
.box.green{background:#66ff66}
Html
&#60;div class=&#34;box gray fs-12 pd-20&#34;&#62;this a gray fontsize12px padding20px box&#60;/div&#62;
&#60;div&#160;class=&#34;box green fs-14 pd-10&#34;&#62;this a gray fontsize14px padding10px box&#60;/div&#62;
….
我们看一些虽然 在class上引用了几个，但是代码和逻辑都非常清晰，而且非常容易维护，随意组合随意扩展。从上面可以看到“组合”的方式是不言而喻的，但是也不是十全十美的，再拆分组合的时候一定不要过度，不然效果可能适得其反，只有把组合+继承运用的恰到好处才能让我们的代码更加优雅和艺术。
]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.yupoo.com/photos/view?id=ff80808116131770011617f24e785283" title="来YUPOO看我的照片"><img src="http://photo5.yupoo.com/20071107/103103_148224484_fxfqbnwp.jpg" alt="“少用继承，多用组合”之CSS篇" width="380" height="90" border="0" /></a></p>
<p>继承是 css中经常要用到的技术，好处是可以尽量让页面的代码减少重复利用，但是随时项目越来越大，需求的不断变化，css代码就会变得越来越臃肿，后期难以控制和维护。其实，css代码和普通程序代码在编写的时候有很多的相似之处，下面我们就用试试用组合的方式是不是能更好的解决这个问题。</p>
<p>下面是一段普通的代码:<br />
css:</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Blue;">.box</span><span style="color: Olive;">{</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">border:</span><span style="color: Maroon;">1</span><span style="color: Red;">px</span><span style="color: Gray;">&nbsp;</span><span style="color: Red;">solid</span><span style="color: Gray;"> </span><span style="color: #00008b;">#ccc</span><span style="color: Gray;">;</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">font-size:</span><span style="color: Maroon;">12</span><span style="color: Red;">px</span><span style="color: Gray;">;</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">background:</span><span style="color: #00008b;">#f1f1f1</span><span style="color: Gray;">;</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">padding:</span><span style="color: Maroon;">10</span><span style="color: Red;">px</span><span style="color: Gray;">;</span></li>
<li><span style="color: Olive;">}</span></li></ol></div>
<p>html：</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Olive;">&lt;</span><span style="color: Green;">div</span><span style="color: Gray;"> </span><span style="color: #00008b;">class</span><span style="color: Gray;">=</span><span style="color: #8b0000;">&quot;</span><span style="color: Red;">box</span><span style="color: #8b0000;">&quot;</span><span style="color: Olive;">&gt;</span><span style="color: Gray;">this is&nbsp; a gray box</span><span style="color: Olive;">&lt;/</span><span style="color: Green;">div</span><span style="color: Olive;">&gt;</span></li></ol></div>
<p><span id="more-171"></span></p>
<p>但是这个时候需求增加了，在页面中不仅要有一个灰色的盒子可能还有蓝色的盒子，可能还有绿色，通常我们会说用集成嘛，好我们就做如下更改<br />
css:</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Blue;">.box-gray</span><span style="color: Gray;">,</span></li>
<li><span style="color: Blue;">.box-green</span><span style="color: Olive;">{</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">border:</span><span style="color: Maroon;">1</span><span style="color: Red;">px</span><span style="color: Gray;">&nbsp;</span><span style="color: Red;">solid</span><span style="color: Gray;"> </span><span style="color: #00008b;">#ccc</span><span style="color: Gray;">;</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">font-size:</span><span style="color: Maroon;">12</span><span style="color: Red;">px</span><span style="color: Gray;">;</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">padding:</span><span style="color: Maroon;">10</span><span style="color: Red;">px</span><span style="color: Gray;">;</span></li>
<li><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.box-gray</span><span style="color: Olive;">{</span><span style="color: Green;">background:</span><span style="color: #00008b;">#f1f1f1</span><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.box-green</span><span style="color: Olive;">{</span><span style="color: Green;">background:</span><span style="color: #00008b;">#66ff66</span><span style="color: Olive;">}</span></li></ol></div>
<p>Html:</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Olive;">&lt;</span><span style="color: Green;">div</span><span style="color: Gray;"> </span><span style="color: #00008b;">class</span><span style="color: Gray;">=</span><span style="color: #8b0000;">&quot;</span><span style="color: Red;">box-gray</span><span style="color: #8b0000;">&quot;</span><span style="color: Olive;">&gt;</span><span style="color: Gray;">this is&nbsp; a gray box</span><span style="color: Olive;">&lt;/</span><span style="color: Green;">div</span><span style="color: Olive;">&gt;</span></li>
<li><span style="color: Olive;">&lt;</span><span style="color: Green;">div</span><span style="color: Gray;">&nbsp;</span><span style="color: #00008b;">class</span><span style="color: Gray;">=</span><span style="color: #8b0000;">&quot;</span><span style="color: Red;">box-green</span><span style="color: #8b0000;">&quot;</span><span style="color: Olive;">&gt;</span><span style="color: Gray;">this is a green box</span><span style="color: Olive;">&lt;/</span><span style="color: Green;">div</span><span style="color: Olive;">&gt;</span></li></ol></div>
<p>但是这个时候需求又有变化了，根与应用的不同，盒子中有些要用到12号字，有些要用到14号字，有些要变局10px有些要20px，估计这个时候你就要头大了，如果要用用继承css代码就会变得异常的复杂，那我们就来试验一下用组合的方式看能不能解决。<br />
css:</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Blue;">.fs-12</span><span style="color: Olive;">{</span><span style="color: Green;">font-size:</span><span style="color: Maroon;">12</span><span style="color: Red;">px</span><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.fs-14</span><span style="color: Olive;">{</span><span style="color: Green;">font-size:</span><span style="color: Maroon;">14</span><span style="color: Red;">px</span><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.pd-10</span><span style="color: Olive;">{</span><span style="color: Green;">padding:</span><span style="color: Maroon;">10</span><span style="color: Red;">px</span><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.pd-20</span><span style="color: Olive;">{</span><span style="color: Green;">padding:</span><span style="color: Maroon;">20</span><span style="color: Red;">px</span><span style="color: Olive;">}</span></li>
<li><span style="color: Gray;">&nbsp;</span></li>
<li><span style="color: Blue;">.box</span><span style="color: Olive;">{</span></li>
<li><span style="color: Gray;">&nbsp; </span><span style="color: Green;">border:</span><span style="color: Maroon;">1</span><span style="color: Red;">px</span><span style="color: Gray;">&nbsp;</span><span style="color: Red;">solid</span><span style="color: Gray;"> </span><span style="color: #00008b;">#ccc</span><span style="color: Gray;">;</span></li>
<li><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.box.gray</span><span style="color: Olive;">{</span><span style="color: Green;">background:</span><span style="color: #00008b;">#f1f1f1</span><span style="color: Olive;">}</span></li>
<li><span style="color: Blue;">.box.green</span><span style="color: Olive;">{</span><span style="color: Green;">background:</span><span style="color: #00008b;">#66ff66</span><span style="color: Olive;">}</span></li></ol></div>
<p>Html</p>
<div class="hl-surround"><ol class="hl-main ln-show" title="Double click to hide line number." ondblclick = "linenumber(this)"><li class="hl-firstline"><span style="color: Olive;">&lt;</span><span style="color: Green;">div</span><span style="color: Gray;"> </span><span style="color: #00008b;">class</span><span style="color: Gray;">=</span><span style="color: #8b0000;">&quot;</span><span style="color: Red;">box gray fs-12 pd-20</span><span style="color: #8b0000;">&quot;</span><span style="color: Olive;">&gt;</span><span style="color: Gray;">this a gray fontsize12px padding20px box</span><span style="color: Olive;">&lt;/</span><span style="color: Green;">div</span><span style="color: Olive;">&gt;</span></li>
<li><span style="color: Olive;">&lt;</span><span style="color: Green;">div</span><span style="color: Gray;">&nbsp;</span><span style="color: #00008b;">class</span><span style="color: Gray;">=</span><span style="color: #8b0000;">&quot;</span><span style="color: Red;">box green fs-14 pd-10</span><span style="color: #8b0000;">&quot;</span><span style="color: Olive;">&gt;</span><span style="color: Gray;">this a gray fontsize14px padding10px box</span><span style="color: Olive;">&lt;/</span><span style="color: Green;">div</span><span style="color: Olive;">&gt;</span></li>
<li><span style="color: Gray;">….</span></li></ol></div>
<p>我们看一些虽然 在class上引用了几个，但是代码和逻辑都非常清晰，而且非常容易维护，随意组合随意扩展。从上面可以看到“组合”的方式是不言而喻的，但是也不是十全十美的，再拆分组合的时候一定不要过度，不然效果可能适得其反，只有把组合+继承运用的恰到好处才能让我们的代码更加优雅和艺术。</p>
]]></content:encoded>
			<wfw:commentRss>http://blog.d8in.com/posts/171.html/feed</wfw:commentRss>
		<slash:comments>9</slash:comments>
		</item>
	</channel>
</rss>
