CSS框架960Grid从入门到精通一步登天

简介: 闲言少叙,废话不说,直入正题:1、什么是CSS框架?    CSS框架是一种你能够使用在你的web项目中概念上的结构,是别人已经写完的,而且很完善的CSS定义集合。CSS框架一般是CSS文件的集合,包括基本风格的字体排版,表单样式,表格布局等等,比如:    * grid.css 表格布局    * layout.css 布局    * form.css 表单    * general.css CSS常规设置2、CSS框架的种类:    CSS框架很多,可以说太多了,最近几年像潮水般涌出。

闲言少叙,废话不说,直入正题:

1、什么是CSS框架?
    CSS框架是一种你能够使用在你的web项目中概念上的结构,是别人已经写完的,而且很完善的CSS定义集合。CSS框架一般是CSS文件的集合,包括基本风格的字体排版,表单样式,表格布局等等,比如:
    * grid.css 表格布局
    * layout.css 布局
    * form.css 表单
    * general.css CSS常规设置

2、CSS框架的种类:
    CSS框架很多,可以说太多了,最近几年像潮水般涌出。只是国内用CSS框架的不多,倒是PHP框架和Spring框架用的更多些。比较著名的CSS框架如下,不同的框架完成的任务不一定完全一样,每个框架都有自己的特色:
    YUI Grids CSS             Blueprint               YAML CSS Framework            CleverCSS
       等等。。。。。。

3、960Grid
        由于电脑显示器有方屏、宽屏,宽屏又分16:9和16:10。分辨率更是多种多样,这么多不同模式下得用户如何能看到外观整齐、一致的网站呢?人们发现一个奇妙的事情:960px的宽度是Very Good!无论什么屏,那种分辨率都通吃。
        现在有人专门开发了一组网站架构CSS规则,只要遵守这些简单的规则(其实就是class类),你就能快速设计出960px宽度的网页结构来。
        这,就是960Grid。
        官网: http://960.gs/

4、法律问题
    960网格系统的文件都是免费的,MIT / GPL开源许可协议。大家可以放心大胆使用。

5、如何使用960Grid框架?
(1)在html文件中引入相关的外部CSS文件:
  1. link rel="stylesheet" href="css/reset.css" />
  2. link rel="stylesheet" href="css/text.css" />
  3. link rel="stylesheet" href="css/960.css" />
      在这必须解释一下,960.css为主要排版样式,缺它肯定不行。还有两个css文件:reset.css和text.css,它们的主要作用是为了消除浏览器间显示差异准备的,前者消除了html标签在各浏览器间的差异,而后者则主要针对的是字体。

(2)定义一个DIV大容器,放下整个页面:
  1. div class="container_12">
  2. /div>
    这个DIV块一定要设定12列还是16列,其实不管12列还是16列宽度都是960px,只不过看你需不需要更细分的列了。

(3)在这个DIV大容器里开始布局网页,首先添加一个LOGO栏,这个栏横向跨越整个960宽度:
  1. div class="container_12">
  2.     div class="grid_12">/div>
  3. /div>
    此时,注意了,在12列的container中,使用了一个12列的grid, 下划线后数字就是该DIV所占的列数。当然为了布局方便,我们一定会加入更多的class或id的,最后如下:
  1. div class="container_12">
  2.     div class="grid_12 logo">/div>
  3. /div>
    设置好.logo的CSS的高和背景图片后,能看到如下图所示的界面:
img_44dd6a16e6ff312d100a7557c2cd3d98.jpg

(4)设置导航栏
    刚才那个logo块其实已经完工了,但为了清除它对身后的CSS设置影响, 建议在每个横向DIV大块做完之后,都加上class="clear"进行收尾。所以刚才的代码现在更改如下:
  1. div class="container_12">
  2.     div class="grid_12">/div>
  3.     div class="clear">/div>
  4. /div>
    然后再加入导航栏的DIV块,和LOGO一样,也是一个横向大块,设置后代码如下:
  1. div class="container_12">
  2.     div class="grid_12 logo">/div>
  3.     div class="clear">/div>
  4.     div class="grid_12 nav">
  5.        
    • ...
  6.     /div>
  7.     div class="clear">/div>
  8. /div>
    添加样式后,网页变为这样:
img_cf3724d4fbdd05f6c9ee7af4f3198f35.jpg

(5)添加PhotoSlide的位置
    一般网站为了漂亮和醒目,会在nav下加入photoslide,有的是js的,有的是flash的,但无论哪种都能把网站衬托起来。当然例子中就不真的放photoslide了。现在要把横行分为两个部分:left和right,left写文字,right放个图片提提神。
    按原案例样子,left会占据7列的宽度,right将占据5列的宽度,7+5=12列!所以一个class用grid_7,另一个用gird_5。然后直接在块后加上clear类。由于这两个块高度一致,边框也一致,所以都加入一个topslider类设置它们的共同特征。
    现在把代码写好:
  1. div class="container_12">
  2.     div class="grid_12 logo">/div>
  3.     div class="clear">/div>
  4.     div class="grid_12 nav">
  5.         ul>.../ul>
  6.     /div>
  7.     div class="clear">/div>

  8.     div class="grid_7 topslider">/div>
  9.     div class="grid_5 topslider">/div>
  10.     div class="clear">/div>
  11. /div>
    填入其它Html标记和各种素材,完成后,如下图所示:
img_70d7de313cbe7e6e3c1b9331076540de.jpg

(6)完成接下来的代码
    用两段grid_12的名为class="spacer"的div夹住四篇文章部分,四篇文章分别使用四个grid_3来完成。为什么是四个grid_3呢?横向12列,4篇等宽文章,每篇12/4=3!如果到现在你还有这个疑问,说明你其实没弄明白960grid的原理。建议回到页首再看下来。
    加入很多代码后:
  1. div class="container_12">
  2.     div class="grid_12 logo">/div>
  3.     div class="clear">/div>
  4.     div class="grid_12 nav">
  5.         ul>.../ul>
  6.     /div>
  7.     div class="clear">/div>

  8.     div class="grid_7 topslider">/div>
  9.     div class="grid_5 topslider">/div>
  10.     div class="clear">/div>
  11.     div class="grid_12 spacer">/div>
  12.     div class="clear">/div>
  13.   
  14.     div class="grid_3">/div>
  15.     div class="grid_3">/div>
  16.     div class="grid_3">/div>
  17.     div class="grid_3">/div>
  18.   
  19.     div class="clear">/div>
  20.   
  21.     div class="grid_12 spacer">/div>
  22.     div class="clear">/div>
  23.   
  24.     div class="grid_4 footer">/div> 
  25.     div class="grid_4 footer">/div>
  26.     div class="grid_4 footer">/div>
  27. /div>
    然后添加内容,设置CSS,就是这个页面了:
img_1f16bc6c33679b583a126dd794b98138.jpg

    到目前为止,能明白960Grid原理就达到目的。接下来的是关于这个框架的高级内容部分。

高级部分:
(1)alpha和omega参数
    默认情况下,左右margin都是10px,则列间距为20px,但最左边的容器不需要左margin,最右边的容器不需要右margin,所以要改成这样,用alpha出去左margin,omega除去右margin:
  1. div class="container_12″>
  2.     div class="grid_2 alpha">左侧导航栏/div>
  3.     div class="grid_8″>主版块/div>
  4.     div class="grid_2 omega">右侧广告栏/div>
  5. /div>
(2)prefix和suffix参数
    如同上面那两个margin快捷参数一样,不必非得单独为某个div单独命名id或class,960Grid已经提供了prefix和suffix来处理padding。左侧补白(padding-left)是prefix_i,右侧的是suffix_i。i的值就是补白所占的列数,比如你想左侧加2列补白,则可以使用:
  1. div class="grid_5 prefix_2">/div>
    多简单。

(3)push和pull参数
    最绝的还是这两个参数,一般人用的不多。因为大家都满足自己的网页宽度是960px了,如果现在真想把其中一个涉及到图片或广告的div做到1024px宽,怎么办?其实很好解决,一个div做reletive,它的子div的为absolue并且left为负值就可以,但这种CSS有点麻烦。
    960Grid提供push和pull参数,push是推,pull是拉。关键是在什么位置推拉,就是说那里才是动作的起点?我们浏览网页时几乎都是自左向右看,所以该动作也以左侧为起点,现在想象你就站在最左边。push_i就是把一个块向右推移i个列宽,pull_i就是把这个块向左拉i个列宽。
    push和pull动作对其他兄弟块没有影响。可以直接推出960px去它就在整个网页右边独单显示了,也可以pull出来,就在左边单独显示了。有点像sohu侧边广告的感觉。上个图,直观感受下吧,但sohu可不是用push和pull做出来的,我的意思是和sohu的效果一样。
img_feda74bf8215ac5a7514895c624377ea.jpg


(4)clear参数
    class="clear",什么时候用呢。当你想换行的时候就使用它,即使一个横行只有grid_5和grid_4,就是说没有占满12列,也可以在其后增加一个让其后的任何内容都从下一行行首开始:
  1. div class="clear">/div>
    如果遇到这种情况:
  1. div class="grid_4">/div>
  2. div class="grid_5">/div>

  3. div class="clear">/div>

  4. div class="grid_3">/div>
    原本横向占满12列的4+5+3,中间夹个clear。会发生什么事呢?grid_3这个块就会从下一个横行最左边出现。所以clear就是一个回车,相当于
块的

    好了总结下:
    A、margin参数是alpha和omega;
    B、padding参数是prefix和suffix;
    C、脱离文档流移动参数是push和pull;
    D、clear是块回车换行。

    就写到这里吧。五岳之巅原创,转载请注明出处。


相关文章
|
10天前
|
Web App开发 前端开发
【CSS】——基础入门常见操作
CSS引入,CSS对元素美化,style修饰,选择器(标签选择器,类选择器,ID选择器,复合选择器),font-size , boder ,width,height,margin,paddiing
|
6月前
|
前端开发
|
4月前
|
前端开发
【前端web入门第四天】02 CSS三大特性+背景图
本文详细介绍了CSS的三大特性:继承性、层叠性和优先级,并深入讲解了背景图的相关属性,包括背景属性、背景图的平铺方式、位置设定、缩放、固定以及复合属性。其中,继承性指子元素自动继承父元素的文字控制属性;层叠性指相同属性后定义覆盖前定义,不同属性可叠加;优先级涉及选择器权重,包括行内样式、ID选择器等。背景图部分则通过具体示例展示了如何设置背景图像的位置、大小及固定方式等。
270 91
|
3月前
|
前端开发 容器
使用 CSS Grid 布局实现响应式设计
【10月更文挑战第1天】使用 CSS Grid 布局实现响应式设计
71 4
|
3月前
|
前端开发 容器
前端技术分享:利用CSS Grid布局实现响应式设计
【10月更文挑战第1天】前端技术分享:利用CSS Grid布局实现响应式设计
|
3月前
|
前端开发 UED 容器
前端技术分享:利用 CSS Grid 实现响应式布局
【10月更文挑战第1天】前端技术分享:利用 CSS Grid 实现响应式布局
82 2
|
4月前
|
前端开发
【前端web入门第三天】02 CSS字体和文本
本文详细介绍了CSS中字体和文本的相关属性。字体部分涵盖字体大小、粗细、样式、行高、字体族及`font`复合属性,通过具体示例展示了如何设置和使用这些属性。文本部分则讲解了文本缩进、对齐方式、修饰线及文字颜色等属性,并提供了实用的代码示例。此外,还简要介绍了调试工具中的一些细节,如错误属性标识和属性生效状态的控制。
77 28
|
4月前
|
前端开发 JavaScript
【前端web入门第三天】01 css定义和引入方式 四种标签选择器
本文档详细介绍了CSS的基础知识及其应用。内容涵盖了CSS的定义、CSS在HTML中的引入方式,包括内部样式表、外部样式表及行内样式表的使用场景与方法。此外,还深入解析了不同种类的选择器:标签选择器、类选择器、ID选择器以及通配符选择器的功能与应用场景,并提供了实例帮助理解。最后,通过具体的新属性示例,指导如何使用这些选择器来实现基本的盒子绘制。适合初学者系统学习CSS。
63 15
|
4月前
|
前端开发
|
4月前
|
前端开发
【前端web入门第六天】01 CSS浮动
这是关于CSS布局第六天学习目标的介绍,主要解决多个`<div>`标签在同一行显示的问题,即一个在左边,另一个在右边。文中介绍了标准流、浮动及flex布局的概念,重点推荐使用flex布局。文章详细讲解了浮动的基本使用、布局技巧及清除浮动的方法,包括额外标签法、单伪元素法、双伪元素法和`overflow`隐藏法,并提供了示例代码帮助理解。

热门文章

最新文章