学习使用Bootstrap栅格系统


Posted in Javascript onMay 11, 2017

Bootstrap之栅格系统

Bootstrap 提供了一套响应式、移动设备优先的流式栅格系统。

一. 移动设备优先

所谓移动设备优先,重要的是屏幕,不是设备。

移动设备优先就是说起初样式是在移动设备写的,然后写到sm尺寸的时候样式得改变了,于是就加media screen max-width >=768, 再写sm的样式,这样尺寸递进就完成了所有的媒体查询,由于不加media query的样式是在最小尺寸,也就是移动设备上写的,所以叫做移动设备优先。

移动设备优先有一份非常重要的 meta,用于设置屏幕和设备等宽以及是否运行用户缩放,及缩放比例的问题。

//分别为:屏幕宽度和设备一致、初始缩放比例、最大缩放比例和禁止用户缩放

<meta name="viewport" content="width=device-width, initial-scale=1,maximum-scale=1, user-scalable=no">

二. 栅格系统

1. 布局容器

Bootstrap 需要为页面内容和栅格系统包裹一个.container容器。由于 padding等属性的原因,这两种容器类不能相互嵌套。

//固定宽度
<div class="container"></div>

//100%宽度
<div class="container-fluid"></div>

栅格系统中,浏览器会随着屏幕的大小的增减自动分配最多12列。通过一系列的行(row)与列(column)的组合来创建页面布局。

2. 栅格系统工作原理:

“行(row)”必须包含在 .container (固定宽度)或 .container-fluid(100%宽度)中,以便为其赋予合适的排列(aligment)和内补(padding)。

通过“行(row)”在水平方向创建一组“列(column)”。

你的内容应当放置于“列(column)”内,并且,只有“列(column)”可以作为行(row)”的直接子元素。

类似 .row和 .col-xs-4 这种预定义的类,可以用来快速创建栅格布局。Bootstrap 源码中定义的 mixin也可以用来创建语义化的布局。

通过为“列(column)”设置 padding 属性,从而创建列与列之间的间隔(gutter)。通过为 .row 元素设置负值 margin 从而抵消掉为 .container 元素设置的padding,也就间接为“行(row)”所包含的“列(column)”抵消掉了 padding。

负值的 margin在栅格列中的内容排成一行。

栅格系统中的列是通过指定 1 到 12 的值来表示其跨越的范围。例如,三个等宽的列可以使用三个 .col-xs-4 来创建。

如果一“行(row)”中包含了的“列(column)”大于 12,多余的“列(column)”所在的元素将被作为一个整体另起一行排列。

栅格类适用于与屏幕宽度大于或等于分界点大小的设备 , 并且针对小屏幕设备覆盖栅格类。 因此,在元素上应用任何 .col-md-* 栅格类适用于与屏幕宽度大于或等于分界点大小的设备 ,并且针对小屏幕设备覆盖栅格类。因此,在元素上应用任何 .col-lg-*不存在, 也影响大屏幕设备。

3. 栅格参数

学习使用Bootstrap栅格系统

栅格系统最外层区分了四种宽度的浏览器:超小屏(<768px)、小屏(>=768px)、中屏(>=992px)和大屏(>=1200px)。而内层.container 容器的自适应宽度为:自动、750px、970px 和 1170px。自动的意思为,如果你是手机屏幕,则全面独占一行显示。

4. 实践演示代码

<!DOCTYPE html>
  <html lang="en">
  <head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scale=no">
  <title>栅格系统</title>
  <link rel="stylesheet" href="../bootstrap-3.3.4/css/bootstrap.min.css" rel="external nofollow" >
  <style>
  .a{
    height:50px;
    border: 1px solid black;
    background-color: #ccc;
  }
  .b{
    height:100px;
    border: 1px solid black;
    background-color: #eee;
  }
  </style>
  </head>
  <body>

  <div class="container a ">
    固定宽度
  </div>
  <div class="container-fluid b ">
    100%宽度
  </div>

  <br><!-- 创建最多 12 列的响应式行(问题:当屏幕小于一定程度时,每行只会显示1列) -->
  <div class="container ">
    <div class="row">
      <div class="col-md-1 a">1</div>
      <div class="col-md-1 a">2</div>
      <div class="col-md-1 a">3</div>
      <div class="col-md-1 a">4</div>
      <div class="col-md-1 a">5</div>
      <div class="col-md-1 a">6</div>
      <div class="col-md-1 a">7</div>
      <div class="col-md-1 a">8</div>
      <div class="col-md-1 a">9</div>
      <div class="col-md-1 a">10</div>
      <div class="col-md-1 a">11</div>
      <div class="col-md-1 a">12</div>
    </div>
    <div class="row">
      <div class="col-md-8 a">8</div>
      <div class="col-md-4 a">4</div>
    </div>
    <div class="row">
      <div class="col-md-4 a">4</div>
      <div class="col-md-4 a">4</div>
      <div class="col-md-4 a">4</div>
    </div>
  </div>

  <br><!-- 四种屏幕分类全部激活,大屏幕是每行显示4列,中等屏幕每行显示3列,小屏幕和超小屏幕每行显示2列 -->
  <div class="container">
    <div class="row">
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
      <div class="col-lg-3 col-md-4 col-sm-6 col-xs-6 a">4</div>
    </div>
  </div>

  <br><!-- 列偏移,中间保持空隙 -->
  <div class="container">
    <div class="row">
      <div class="col-md-8 a">8</div>
      <div class="col-md-3 col-md-offset-1 a">3</div>
    </div>
  </div>

  <br><!-- 嵌套,嵌满也是 12 列 -->
  <div class="container">
    <div class="row">
      <div class="col-md-9 a">
        <div class="col-md-8 a">1-8</div>
        <div class="col-md-4 a">9-12</div>
      </div>
      <div class="col-md-3 a">11-12</div>
    </div>
  </div>

  <br><!-- 交换列的位置 -->
  <div class="container">
    <div class="row">
      <div class="col-md-9 a">9</div> <!-- 向右移动3列 -->
      <div class="col-md-3 a">3</div> <!-- 向左移动9列 -->
    </div>
    <div class="row">
      <div class="col-md-9 col-md-push-3 a">9</div> <!-- 向右移动3列,push 向右移动 -->
      <div class="col-md-3 col-md-pull-9 a">3</div> <!-- 向左移动9列,pull 向左移动 -->
    </div>
  </div>
  </body>
  </html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript和ActionScript的交互实现代码
Aug 01 Javascript
Javascript合并表格中具有相同内容单元格示例
Aug 11 Javascript
jQuery 回车事件enter使用示例
Feb 18 Javascript
基于javascript实现checkbox复选框实例代码
Jan 28 Javascript
js点击按钮实现水波纹效果代码(CSS3和Canves)
Sep 15 Javascript
Canvas实现放射线动画效果
Feb 15 Javascript
Vue.js 60分钟快速入门教程
Mar 28 Javascript
Node.js 8 中的 util.promisify的详解
Jun 12 Javascript
AngularJS模态框模板ngDialog的使用详解
May 11 Javascript
JS实现可针对算术表达式求值的计算器功能示例
Sep 04 Javascript
微信小程序实现图片翻转效果的实例代码
Sep 20 Javascript
vue+axios 拦截器实现统一token的案例
Sep 11 Javascript
jQuery实现的简单在线计算器功能
May 11 #jQuery
学习使用Bootstrap页面排版样式
May 11 #Javascript
Angularjs 与 bower安装和使用详解
May 11 #Javascript
学习使用Bootstrap输入框、导航、分页等常用组件
May 11 #Javascript
es6学习笔记之Async函数基本教程
May 11 #Javascript
Bootstrap模态框插件使用详解
May 11 #Javascript
canvas实现弧形可拖动进度条效果
May 11 #Javascript
You might like
更改localhost为其他名字的方法
2014/02/10 PHP
php的debug相关函数用法示例
2016/07/11 PHP
PHP For循环字母A-Z当超过26个字母时输出AA,AB,AC
2020/02/16 PHP
javascript游戏开发之《三国志曹操传》零部件开发(一)让静态人物动起来
2013/01/23 Javascript
IE下使用jQuery重置iframe地址时内存泄露问题解决办法
2015/02/05 Javascript
JavaScript原生对象之Date对象的属性和方法详解
2015/03/13 Javascript
详解JavaScript的Polymer框架中的通知交互
2015/07/29 Javascript
一个php+js实时显示时间问题
2015/10/12 Javascript
深入浅析knockout源码分析之订阅
2016/07/12 Javascript
jQuery实现的超链接提示效果示例【附demo源码下载】
2016/09/09 Javascript
微信小程序(应用号)简单实例应用及实例详解
2016/09/26 Javascript
JS跨域请求外部服务器的资源
2017/02/06 Javascript
详解webpack 入门总结和实践(按需异步加载,css单独打包,生成多个入口文件)
2017/06/20 Javascript
vue+iview+less+echarts实战项目总结
2018/02/22 Javascript
微信小程序全局变量功能与用法详解
2019/01/22 Javascript
分享JS表单验证源码(带错误提示及密码等级)
2020/01/05 Javascript
Ant Design moment对象和字符串之间的相互转化教程
2020/10/27 Javascript
[47:06]DOTA2上海特级锦标赛主赛事日 - 4 败者组第五轮 MVP.Phx VS EG第一局
2016/03/05 DOTA
在Mac OS上部署Nginx和FastCGI以及Flask框架的教程
2015/05/02 Python
python 输出列表元素实例(以空格/逗号为分隔符)
2019/12/25 Python
VS2019+python3.7+opencv4.1+tensorflow1.13配置详解
2020/04/16 Python
python矩阵运算,转置,逆运算,共轭矩阵实例
2020/05/11 Python
python使用多线程+socket实现端口扫描
2020/05/28 Python
k-means 聚类算法与Python实现代码
2020/06/01 Python
Django Session和Cookie分别实现记住用户登录状态操作
2020/07/02 Python
Pytho爬虫中Requests设置请求头Headers的方法
2020/09/22 Python
Pycharm学生免费专业版安装教程的方法步骤
2020/09/24 Python
纯CSS3打造动感漂亮时尚的扇形菜单
2014/03/18 HTML / CSS
爱游人:Travelliker
2017/09/05 全球购物
Delphi软件工程师试题
2013/01/29 面试题
大跃进口号
2014/06/16 职场文书
本科毕业论文指导教师评语
2014/12/30 职场文书
同意转租证明
2015/06/24 职场文书
考试后的感想
2015/08/07 职场文书
详解Python 3.10 中的新功能和变化
2021/04/28 Python
修改MySQL的默认密码的四种小方法
2021/05/26 MySQL