熟悉Bootstrap的同学应该了解其中的格栅系统,用来排版非常方便。他将页面分为12等分,并且适用不同的尺寸屏幕。超小xs(小于768px),小屏sm(大于等于768px),中屏md(大于等于992px),大屏lg(大于等于1200px)。为此需要生成一堆的.clo-*-*类,总计4*12=48个,再加上pull,push,offset。这种只能用less来写了,参考Bootstrap的less源码,自己重新写了一个,仅供练手

Less版本

@sm-width: 768px;
@md-width: 992px;
@lg-width: 1200px;
@grid-columns: 12;
@grid-gutter: 30px;
@container-sm: (720px + @grid-gutter);
@container-md: (940px + @grid-gutter);
@container-lg: (1140px + @grid-gutter); .grid-padding(@gutter){
padding-left: floor((@gutter)/2);
padding-right: floor((@gutter)/2);
}
.make-container() {
.grid-padding(@grid-gutter);
margin-left: auto;
margin-right: auto;
@media (min-width: @sm-width) {
width: @container-sm;
}
@media (min-width: @md-width) {
width: @container-md;
}
@media (min-width: @lg-width) {
width: @container-lg;
}
} .container{
.make-container;
}
.container-fluid{
.grid-padding(@grid-gutter);
margin-left: auto;
margin-right: auto;
}
.row {
margin-left: -15px;
margin-right: -15px;
} .make-grid() {
.col(@index; @list) when(@index  @grid-columns) {
@{item} {
.grid-padding(@grid-gutter);
position: left;
min-height: 1px;
}
} .col(1; '.col-xs-0');
} .make-grid(); .make-column(@class) {
.col(@index; @list) when (@index  @grid-columns) {
@{list} {
float: left;
}
}
.col(1; '.col-@{class}-0');
}
.make-column(xs);
@media (min-width: @sm-width) {
.make-column(sm);
}
@media (min-width: @md-width) {
.make-column(md);
}
@media (min-width: @lg-width) {
.make-column(lg);
}

sass版本

$screen-map: (xs:768px, sm: 768px, md: 992px, lg: 1200px);
$gutter-width: 30px;
$container-map: (sm: 720px + $gutter-width, md: 940px + $gutter-width, lg: 1140px + $gutter-width);
$grid-columns: 12;
$colclass-map: (pull: right, push: left, offset: margin-left); @mixin grid-padding($gutter) {
padding-left: $gutter/2;
padding-right: $gutter/2;
} @mixin margin-auto($horizone:null) {
@if $horizone {
margin: $horizone/2 auto;
}
@else {
margin-left: auto;
margin-right: auto;
}
} @mixin make-container() {
@include grid-padding($gutter-width);
@include margin-auto(); @each $screen, $width in $container-map {
$min-width: map-get($screen-map, $screen);
@media (min-width: $min-width) {
width: $width;
}
}
} .container{
@include make-container();
} .container-fluid{
@include grid-padding($gutter-width);
@include margin-auto();
}
.row {
margin-left: -15px;
margin-right: -15px;
} @mixin make-grid() {
$list: null;
@for $i from 1 through $grid-columns {
@each $screen, $width in $screen-map {
$item: '.col-#{$screen}-#{$i}';
@if $list {
$list: #{$list}, #{$item};
} @else {
$list: $item;
}
}
}
#{$list} {
@include grid-padding($gutter-width);
position: left;
min-height: 1px;
}
} @mixin make-column($screen) {
$list: null;
@for $i from 1 through $grid-columns {
$item: '.col-#{$screen}-#{$i}';
@if $list {
$list: #{$list}, #{$item};
} @else {
$list: $item;
} #{$item} {
width: percentage(($i)/$grid-columns);
}
@each $class, $suffix in $colclass-map {
.col-#{$screen}-#{$class}-#{$i} {
#{$suffix}: percentage(($i)/$grid-columns);
}
}
} #{$list} {
float: left;
}
} @include make-grid();
@each $screen, $width in $screen-map {
@if $screen == xs {
@include make-column($screen);
} @else {
@media (min-width: $width) {
@include make-column($screen);
}
}
}

编译生成对应CSS文件:

.container {
padding-left: 15px;
padding-right: 15px;
margin-left: auto;
margin-right: auto;
}
@media (min-width: 768px) {
.container {
width: 750px;
}
}
@media (min-width: 992px) {
.container {
width: 970px;
}
}
@media (min-width: 1200px) {
.container {
width: 1170px;
}
}
.container-fluid {
padding-left: 15px;
padding-right: 15px;
margin-left: auto;
margin-right: auto;
}
.row {
margin-left: -15px;
margin-right: -15px;
}
.col-xs-0, .col-xs-1, .col-sm-1, .col-md-1, .col-lg-1, .col-xs-2, .col-sm-2, .col-md-2, .col-lg-2, .col-xs-3, .col-sm-3, .col-md-3, .col-lg-3, .col-xs-4, .col-sm-4, .col-md-4, .col-lg-4, .col-xs-5, .col-sm-5, .col-md-5, .col-lg-5, .col-xs-6, .col-sm-6, .col-md-6, .col-lg-6, .col-xs-7, .col-sm-7, .col-md-7, .col-lg-7, .col-xs-8, .col-sm-8, .col-md-8, .col-lg-8, .col-xs-9, .col-sm-9, .col-md-9, .col-lg-9, .col-xs-10, .col-sm-10, .col-md-10, .col-lg-10, .col-xs-11, .col-sm-11, .col-md-11, .col-lg-11, .col-xs-12, .col-sm-12, .col-md-12, .col-lg-12 {
padding-left: 15px;
padding-right: 15px;
position: left;
min-height: 1px;
}
.col-xs-1 {
width: 8.33333333%;
}
.col-xs-pull-1 {
right: 8.33333333%;
}
.col-xs-push-1 {
left: 8.33333333%;
}
.col-xs-offset-1 {
margin-left: 8.33333333%;
}
.col-xs-2 {
width: 16.66666667%;
}
.col-xs-pull-2 {
right: 16.66666667%;
}
.col-xs-push-2 {
left: 16.66666667%;
}
.col-xs-offset-2 {
margin-left: 16.66666667%;
}
.col-xs-3 {
width: 25%;
}
.col-xs-pull-3 {
right: 25%;
}
.col-xs-push-3 {
left: 25%;
}
.col-xs-offset-3 {
margin-left: 25%;
}
.col-xs-4 {
width: 33.33333333%;
}
.col-xs-pull-4 {
right: 33.33333333%;
}
.col-xs-push-4 {
left: 33.33333333%;
}
.col-xs-offset-4 {
margin-left: 33.33333333%;
}
.col-xs-5 {
width: 41.66666667%;
}
.col-xs-pull-5 {
right: 41.66666667%;
}
.col-xs-push-5 {
left: 41.66666667%;
}
.col-xs-offset-5 {
margin-left: 41.66666667%;
}
.col-xs-6 {
width: 50%;
}
.col-xs-pull-6 {
right: 50%;
}
.col-xs-push-6 {
left: 50%;
}
.col-xs-offset-6 {
margin-left: 50%;
}
.col-xs-7 {
width: 58.33333333%;
}
.col-xs-pull-7 {
right: 58.33333333%;
}
.col-xs-push-7 {
left: 58.33333333%;
}
.col-xs-offset-7 {
margin-left: 58.33333333%;
}
.col-xs-8 {
width: 66.66666667%;
}
.col-xs-pull-8 {
right: 66.66666667%;
}
.col-xs-push-8 {
left: 66.66666667%;
}
.col-xs-offset-8 {
margin-left: 66.66666667%;
}
.col-xs-9 {
width: 75%;
}
.col-xs-pull-9 {
right: 75%;
}
.col-xs-push-9 {
left: 75%;
}
.col-xs-offset-9 {
margin-left: 75%;
}
.col-xs-10 {
width: 83.33333333%;
}
.col-xs-pull-10 {
right: 83.33333333%;
}
.col-xs-push-10 {
left: 83.33333333%;
}
.col-xs-offset-10 {
margin-left: 83.33333333%;
}
.col-xs-11 {
width: 91.66666667%;
}
.col-xs-pull-11 {
right: 91.66666667%;
}
.col-xs-push-11 {
left: 91.66666667%;
}
.col-xs-offset-11 {
margin-left: 91.66666667%;
}
.col-xs-12 {
width: 100%;
}
.col-xs-pull-12 {
right: 100%;
}
.col-xs-push-12 {
left: 100%;
}
.col-xs-offset-12 {
margin-left: 100%;
}
.col-xs-0, .col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12 {
float: left;
}
@media (min-width: 768px) {
.col-sm-1 {
width: 8.33333333%;
}
.col-sm-pull-1 {
right: 8.33333333%;
}
.col-sm-push-1 {
left: 8.33333333%;
}
.col-sm-offset-1 {
margin-left: 8.33333333%;
}
.col-sm-2 {
width: 16.66666667%;
}
.col-sm-pull-2 {
right: 16.66666667%;
}
.col-sm-push-2 {
left: 16.66666667%;
}
.col-sm-offset-2 {
margin-left: 16.66666667%;
}
.col-sm-3 {
width: 25%;
}
.col-sm-pull-3 {
right: 25%;
}
.col-sm-push-3 {
left: 25%;
}
.col-sm-offset-3 {
margin-left: 25%;
}
.col-sm-4 {
width: 33.33333333%;
}
.col-sm-pull-4 {
right: 33.33333333%;
}
.col-sm-push-4 {
left: 33.33333333%;
}
.col-sm-offset-4 {
margin-left: 33.33333333%;
}
.col-sm-5 {
width: 41.66666667%;
}
.col-sm-pull-5 {
right: 41.66666667%;
}
.col-sm-push-5 {
left: 41.66666667%;
}
.col-sm-offset-5 {
margin-left: 41.66666667%;
}
.col-sm-6 {
width: 50%;
}
.col-sm-pull-6 {
right: 50%;
}
.col-sm-push-6 {
left: 50%;
}
.col-sm-offset-6 {
margin-left: 50%;
}
.col-sm-7 {
width: 58.33333333%;
}
.col-sm-pull-7 {
right: 58.33333333%;
}
.col-sm-push-7 {
left: 58.33333333%;
}
.col-sm-offset-7 {
margin-left: 58.33333333%;
}
.col-sm-8 {
width: 66.66666667%;
}
.col-sm-pull-8 {
right: 66.66666667%;
}
.col-sm-push-8 {
left: 66.66666667%;
}
.col-sm-offset-8 {
margin-left: 66.66666667%;
}
.col-sm-9 {
width: 75%;
}
.col-sm-pull-9 {
right: 75%;
}
.col-sm-push-9 {
left: 75%;
}
.col-sm-offset-9 {
margin-left: 75%;
}
.col-sm-10 {
width: 83.33333333%;
}
.col-sm-pull-10 {
right: 83.33333333%;
}
.col-sm-push-10 {
left: 83.33333333%;
}
.col-sm-offset-10 {
margin-left: 83.33333333%;
}
.col-sm-11 {
width: 91.66666667%;
}
.col-sm-pull-11 {
right: 91.66666667%;
}
.col-sm-push-11 {
left: 91.66666667%;
}
.col-sm-offset-11 {
margin-left: 91.66666667%;
}
.col-sm-12 {
width: 100%;
}
.col-sm-pull-12 {
right: 100%;
}
.col-sm-push-12 {
left: 100%;
}
.col-sm-offset-12 {
margin-left: 100%;
}
.col-sm-0, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12 {
float: left;
}
}
@media (min-width: 992px) {
.col-md-1 {
width: 8.33333333%;
}
.col-md-pull-1 {
right: 8.33333333%;
}
.col-md-push-1 {
left: 8.33333333%;
}
.col-md-offset-1 {
margin-left: 8.33333333%;
}
.col-md-2 {
width: 16.66666667%;
}
.col-md-pull-2 {
right: 16.66666667%;
}
.col-md-push-2 {
left: 16.66666667%;
}
.col-md-offset-2 {
margin-left: 16.66666667%;
}
.col-md-3 {
width: 25%;
}
.col-md-pull-3 {
right: 25%;
}
.col-md-push-3 {
left: 25%;
}
.col-md-offset-3 {
margin-left: 25%;
}
.col-md-4 {
width: 33.33333333%;
}
.col-md-pull-4 {
right: 33.33333333%;
}
.col-md-push-4 {
left: 33.33333333%;
}
.col-md-offset-4 {
margin-left: 33.33333333%;
}
.col-md-5 {
width: 41.66666667%;
}
.col-md-pull-5 {
right: 41.66666667%;
}
.col-md-push-5 {
left: 41.66666667%;
}
.col-md-offset-5 {
margin-left: 41.66666667%;
}
.col-md-6 {
width: 50%;
}
.col-md-pull-6 {
right: 50%;
}
.col-md-push-6 {
left: 50%;
}
.col-md-offset-6 {
margin-left: 50%;
}
.col-md-7 {
width: 58.33333333%;
}
.col-md-pull-7 {
right: 58.33333333%;
}
.col-md-push-7 {
left: 58.33333333%;
}
.col-md-offset-7 {
margin-left: 58.33333333%;
}
.col-md-8 {
width: 66.66666667%;
}
.col-md-pull-8 {
right: 66.66666667%;
}
.col-md-push-8 {
left: 66.66666667%;
}
.col-md-offset-8 {
margin-left: 66.66666667%;
}
.col-md-9 {
width: 75%;
}
.col-md-pull-9 {
right: 75%;
}
.col-md-push-9 {
left: 75%;
}
.col-md-offset-9 {
margin-left: 75%;
}
.col-md-10 {
width: 83.33333333%;
}
.col-md-pull-10 {
right: 83.33333333%;
}
.col-md-push-10 {
left: 83.33333333%;
}
.col-md-offset-10 {
margin-left: 83.33333333%;
}
.col-md-11 {
width: 91.66666667%;
}
.col-md-pull-11 {
right: 91.66666667%;
}
.col-md-push-11 {
left: 91.66666667%;
}
.col-md-offset-11 {
margin-left: 91.66666667%;
}
.col-md-12 {
width: 100%;
}
.col-md-pull-12 {
right: 100%;
}
.col-md-push-12 {
left: 100%;
}
.col-md-offset-12 {
margin-left: 100%;
}
.col-md-0, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12 {
float: left;
}
}
@media (min-width: 1200px) {
.col-lg-1 {
width: 8.33333333%;
}
.col-lg-pull-1 {
right: 8.33333333%;
}
.col-lg-push-1 {
left: 8.33333333%;
}
.col-lg-offset-1 {
margin-left: 8.33333333%;
}
.col-lg-2 {
width: 16.66666667%;
}
.col-lg-pull-2 {
right: 16.66666667%;
}
.col-lg-push-2 {
left: 16.66666667%;
}
.col-lg-offset-2 {
margin-left: 16.66666667%;
}
.col-lg-3 {
width: 25%;
}
.col-lg-pull-3 {
right: 25%;
}
.col-lg-push-3 {
left: 25%;
}
.col-lg-offset-3 {
margin-left: 25%;
}
.col-lg-4 {
width: 33.33333333%;
}
.col-lg-pull-4 {
right: 33.33333333%;
}
.col-lg-push-4 {
left: 33.33333333%;
}
.col-lg-offset-4 {
margin-left: 33.33333333%;
}
.col-lg-5 {
width: 41.66666667%;
}
.col-lg-pull-5 {
right: 41.66666667%;
}
.col-lg-push-5 {
left: 41.66666667%;
}
.col-lg-offset-5 {
margin-left: 41.66666667%;
}
.col-lg-6 {
width: 50%;
}
.col-lg-pull-6 {
right: 50%;
}
.col-lg-push-6 {
left: 50%;
}
.col-lg-offset-6 {
margin-left: 50%;
}
.col-lg-7 {
width: 58.33333333%;
}
.col-lg-pull-7 {
right: 58.33333333%;
}
.col-lg-push-7 {
left: 58.33333333%;
}
.col-lg-offset-7 {
margin-left: 58.33333333%;
}
.col-lg-8 {
width: 66.66666667%;
}
.col-lg-pull-8 {
right: 66.66666667%;
}
.col-lg-push-8 {
left: 66.66666667%;
}
.col-lg-offset-8 {
margin-left: 66.66666667%;
}
.col-lg-9 {
width: 75%;
}
.col-lg-pull-9 {
right: 75%;
}
.col-lg-push-9 {
left: 75%;
}
.col-lg-offset-9 {
margin-left: 75%;
}
.col-lg-10 {
width: 83.33333333%;
}
.col-lg-pull-10 {
right: 83.33333333%;
}
.col-lg-push-10 {
left: 83.33333333%;
}
.col-lg-offset-10 {
margin-left: 83.33333333%;
}
.col-lg-11 {
width: 91.66666667%;
}
.col-lg-pull-11 {
right: 91.66666667%;
}
.col-lg-push-11 {
left: 91.66666667%;
}
.col-lg-offset-11 {
margin-left: 91.66666667%;
}
.col-lg-12 {
width: 100%;
}
.col-lg-pull-12 {
right: 100%;
}
.col-lg-push-12 {
left: 100%;
}
.col-lg-offset-12 {
margin-left: 100%;
}
.col-lg-0, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12 {
float: left;
}
}

文章同步发布: https://www.geek-share.com/detail/2765120966.html

使用Less/Sass生成Bootstrap格栅样式系统的更多相关文章

  1. Bootstrap 12 栅格系统

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

  2. CSS高效开发实战:CSS 3、LESS、SASS、Bootstrap、Foundation --读书笔记(1)设定背景图

    技术的新发展,除计算机可以接入互联网之外,平板电脑.智能手机.智能电视等其他设备均可访问互联网.在多设备时代,构建多屏体验也不是听说的那么难. 但是这也增加了学习CSS的难度?不知道如何上手,只懂一点 ...

  3. sass+compass+bootstrap三剑合璧高效开发记录

    1. 先搭建环境,下载node.js,rubyinstaller,安装, 安装rubyinstaller时,要选上include system path,这样就会自动将node.js执行添加到wind ...

  4. [置顶] bootstrap自定义样式-bootstrap侧边导航栏的实现

    前言 bootstrap自带的响应式导航栏是向下滑动的,有时满足不了个性化的需求,需要做一个类似于android drawerLayout 侧滑的菜单,这就是我要实现的bootstrap自定义侧滑菜单 ...

  5. yii使用bootstrap分页样式

    Bootstrap是Twitter推出的一个开源的用于前端开发的工具包.它由Twitter的设计师Mark Otto和Jacob Thornton合作开发,是一个CSS/HTML框架.Bootstra ...

  6. bootstrap课程2 bootstrap的栅格系统的主要作用是什么

    bootstrap课程2  bootstrap的栅格系统的主要作用是什么 一.总结 一句话总结:响应式布局(就是适应不同的屏幕,手机,平板,电脑) 1.bootstrap的栅格系统如何使用? row ...

  7. 只会CSS还不够,LESS、SASS、BootStrap、Foundation一网打尽!

    有些人想学CSS,不知如何下手:有些人已经学会CSS的各种属性,却不知如何运用:有些人会平面设计,不知道如何与网页设计结合:有些人会HTML,就是学不会CSS.试问自己,图中的技术你都会了吗? 别总是 ...

  8. MVC5 + EF6 + Bootstrap3 (7) Bootstrap的栅格系统

    文章来源: Slark.NET-博客园http://www.cnblogs.com/slark/p/mvc5-ef6-bs3-get-started-grid.html 上一节:ASP.NET MVC ...

  9. java生成带html样式的word文件

    参考:http://blog.csdn.net/xiexl/article/details/6652230 最近在项目中需要将通过富文本编辑器处理过的文字转换为Word,查了很久,大家通常的解决办法是 ...

随机推荐

  1. ms5611-01ba03 气压传感器 中英文 数据手册

    中文: https://wenku.baidu.com/view/6f8a861fff00bed5b9f31d53.html 英文: https://wenku.baidu.com/view/fe93 ...

  2. Linux 系统日志和系统信息常用命令介绍

    日志文件 日 志 文 件 说 明 /var/log/message 系统启动后的信息和错误日志,是Red Hat Linux中最常用的日志之一 /var/log/secure 与安全相关的日志信息 / ...

  3. toFixed奇葩问题

    1.浮点数运算后的精度问题 在计算商品价格加减乘除时,偶尔会出现精度问题 // 加法 ===================== 0.1 + 0.2 = 0.30000000000000004 0.7 ...

  4. FPGA最全科普总结

    FPGA最全科普总结   FPGA 是可以先购买再设计的"万能"芯片.FPGA (Field Programmable Gate Array)现场可编程门阵列,是在硅片上预先设计实 ...

  5. 机器学习PAL数据可视化

    机器学习PAL数据可视化 本文以统计全表信息为例,介绍如何进行数据可视化. 前提条件 完成数据预处理,详情请参见数据预处理. 操作步骤 登录PAI控制台. 在左侧导航栏,选择模型开发和训练 >  ...

  6. MindSpore 高阶优化器

    MindSpore 高阶优化器 MindSpore自研优化器THOR(Trace-based Hardware-driven layer-ORiented Natural Gradient Desce ...

  7. YOLOV4知识点分析(一)

    YOLOV4知识点分析(一) 简 介 yolov4论文:YOLOv4: Optimal Speed and Accuracy of Object Detection arxiv:https://arx ...

  8. TensorFlowMNIST数据集逻辑回归处理

    TensorFlow逻辑回归处理MNIST数据集 本节基于回归学习对 MNIST 数据集进行处理,但将添加一些 TensorBoard 总结以便更好地理解 MNIST 数据集. MNIST由https ...

  9. Postman 的基本功能按钮解释、发送post请求及get请求、查看响应信息

    一.界面功能按钮: 二.postman模拟发送post请求: 三.postman模拟get请求: 选择请求类型-->输入请求URL-->点击send发送 四.查看响应信息

  10. 「题解」PA2019 Terytoria

    本文将同步发布于: 洛谷博客: csdn: 博客园: 因为简书系统升级,所以本文未在简书上发布. 题目 题目链接:洛谷 P5987.LOJ 3320.官网. 题意概述 在二维平面直角坐标系上,有一个长 ...