CSS:用Less实现栅格系统

背景

公司一直没有专职的前端和美工,Javascript相对来说我熟悉一点,CSS+HTML有四五年没有搞过了,最近要学一下,招聘或和美工配合的时候会有用处。

收集的资料

知识总结

  • CSS盒子模型:定位和浮动。
  • CSS继承模型:这部分可以边用边记。
  • CSS层叠模型:这部分要记清楚。

最好的教程就是官方教程

栅格系统实战

less

 1 @grid_margin: 20px;
2 @grid_length: 12;
3 @unit: 1px;
4
5 .row {
6 margin-left: -@grid_margin;
7 *zoom: 1;
8 }
9
10 [class*="span"] {
11 float: left;
12 min-height: 1px;
13 margin-left: @grid_margin;
14 }
15
16 .span (@length) when (@length > 0) {
17 .span@{length} {
18 width: (@length * 60 + (@length - 1) * 20) * @unit;
19 }
20
21 .span(@length - 1);
22 }
23
24 .span (0) {}
25
26 .span (@grid_length);
27
28 .offset (@length) when (@length > 0) {
29 .offset@{length} {
30 margin-left: (@length * 60 + (@length + 1) * 20) * @unit;
31 }
32
33 .offset(@length - 1);
34 }
35
36 .offset (0) {}
37
38 .offset (@grid_length);
39
40
41 @grid_margin_percent: (1 / (@grid_length * 4 - 1));
42
43 .row-fluid {
44 width: 100%;
45 *zoom: 1;
46 }
47
48 .row-fluid [class*="span"]:first-child {
49 margin-left: 0;
50 }
51
52 .row-fluid [class*="span"] {
53 display: block;
54 float: left;
55 min-height: 30px;
56 margin-left: percentage(@grid_margin_percent);
57 -webkit-box-sizing: border-box;
58 -moz-box-sizing: border-box;
59 box-sizing: border-box;
60 }
61
62 .fluid_span (@length) when (@length > 0) {
63 .row-fluid .span@{length} {
64 width: percentage((@length * 4 - 1) * @grid_margin_percent);
65 }
66
67 .fluid_span(@length - 1);
68 }
69
70 .fluid_span (0) {}
71
72 .fluid_span (@grid_length);
73
74 .fluid_offset (@length) when (@length > 0) {
75 .row-fluid .offset@{length} {
76 margin-left: percentage((@length * 4 + 1) * @grid_margin_percent);
77 }
78
79 .fluid_offset(@length - 1);
80 }
81
82 .fluid_offset (0) {}
83
84 .fluid_offset (@grid_length);

html

<div class="row">
<div class="span3"></div>
<div class="span6 offset3"></div>
<div class="clear-left"></div>
</div> <div class="row-fluid">
<div class="span3"></div>
<div class="span6 offset3"></div>
<div class="clear-left"></div>
</div>

运行效果

备注

Less多少有些程序语言的味道,刚才的示例写的比较仓促,应该进一步重构,比如:引入解释性的变量,去掉“魔法数字”等。

CSS:用Less实现栅格系统的更多相关文章

  1. BootStrap的table表格,栅格系统,form表单的样式

    BootStrap BootStrap的简介 1.    什么是Bootstrap 由两个前端设计师开发的一个前端的框架(Html,css,js) 简化了程序员写css的代码 2.    为什么使用B ...

  2. CSS:用SASS(SCSS)实现栅格系统

    背景 在CSS:用Less实现栅格系统中我介绍了如何用LESS实现栅格系统,为啥还要再用SASS做一遍呢?Bootstrap+JQuery+Less做前端(以读取为目的),ExtJs+Sass做后台( ...

  3. Bootstrap--全局CSS样式之栅格系统

    Bootstrap 提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列.它包含了易于使用的预定义类,还有强大的mixin 用于生成更具 ...

  4. Bootstrap4中栅格系统CSS中 col-sm-* col-md-* col-lg-*的意义以及当其同时具有col-xs-* col-sm-* col-md-* col-lg-*的含义

    根据Bootstrap--Grid 中 col-sm-* col-md-* col-lg-* col-xl-*的意义: .col-sm-* 小屏幕 手机 (≥ 576px) .col-md-* 中等屏 ...

  5. CSS3简单的栅格系统

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. 初学者--bootstrap(四)栅格系统----在路上(8)

    ---------------------------------------栅格系统:是bootstrap提供的响应式布局方式------------------------------------ ...

  7. Bootstrap之栅格系统

    bootstrap 移动优先 中文官网  http://www.bootcss.com/ 1.基本模板 <!DOCTYPE html> <html lang="en&quo ...

  8. Bootstrap响应式栅格系统的设计原理

    1.历史背景 Bootstrap是Twitter的工程师Mark Otto和Jacob Thornton开发的一套供内部使用的UI框架,于2011年开源.2012年发布的第二版中新增了12列栅格系统和 ...

  9. Bootstrap栅格系统详解,响应式布局

    Bootstrap栅格系统详解 栅格系统介绍 Bootstrap 提供了一套响应式.移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列. 栅格系统用于通 ...

随机推荐

  1. AngularJS + Node.js + MongoDB开发

    AngularJS + Node.js + MongoDB开发的基于位置的通讯录(by vczero) 一.闲扯 有一天班长说了,同学们希望我开发一个可以共享位置的通讯录,于是自己简单设计了下功能.包 ...

  2. bootstrap基本标签总结2

    [布局]bootstrap基本标签总结2   缩略图 <div class="container"> <div class="row"> ...

  3. UI控件库

    UI控件库分享:DWZ(j-UI).LigerUI.Linb DWZ(j-UI): 在线演示地址:http://demo.dwzjs.com 在线文档:http://demo.dwzjs.com/do ...

  4. ASP.NET MVC企业级项目框架

    ASP.NET MVC企业级项目框架 MVC项目搭建笔记---- 项目框架采用ASP.NET MVC+Entity Framwork+Spring.Net等技术搭建,搭建过程内容比较多,结合了抽象工厂 ...

  5. Util应用程序框架公共操作类

    随笔分类 - Util应用程序框架公共操作类 Util应用程序框架公共操作类 Util应用程序框架公共操作类(五):异常公共操作类 摘要: 任何系统都需要处理错误,本文介绍的异常公共操作类,用于对业务 ...

  6. css-fixed兼容写法

    解决IE6中fixed闪动问题(效果稍微好一点,不能完全解决闪动问题) *{background-image:url(about:blank);background-attachment:fixed; ...

  7. 国内外最全面和主流的JS框架与WEB UI库

    当下对于网站前段开发人员来说,很少有人不使用一些JS框架或者WEB UI库,因此这些可以有效提高网站前段开发速度,并且能够统一开发环境,对于不同浏览器的兼容性也不需要程序员操心,有了这些优点,当然大家 ...

  8. gof设计模式回顾

    gof23根据讲师学习笔记回顾: 1.gof:Gang of Four;叫grasp更具有针对性,解决具体的问题; ---------------------总共分为三大类: ---------创建型 ...

  9. OWC11生成统计图案例

    (1)饼状图:----通过修改参数生成不同的走势图, string strCategory = "优良率" + '\t' + "合格率" + '\t' + &q ...

  10. 关于覆盖Object中的hashCode, equals和toString

    最近在看<Effective Java>,里面看到了关于重载hashCode.equals和toString方法的篇章,顿时觉得视野开拓了不少,而且正结合自己工作.项目中的实例,觉得有必要 ...