学习使用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 相关文章推荐
Jquery中对数组的操作代码
Aug 12 Javascript
Jquery实现点击按钮,连续地向textarea中添加值的实例代码
Mar 08 Javascript
JS+CSS实现仿雅虎另类滑动门切换效果
Oct 13 Javascript
JavaScript与HTML的结合方法详解
Nov 23 Javascript
Android中Okhttp3实现上传多张图片同时传递参数
Feb 18 Javascript
JavaScript基于activexobject连接远程数据库SQL Server 2014的方法
Jul 12 Javascript
Easyui Datagrid自定义按钮列(最后面的操作列)
Jul 13 Javascript
简单实现js放大镜效果
Jul 24 Javascript
jQuery实现切换隐藏与显示同时切换图标功能
Oct 29 jQuery
微信小程序实现action-sheet弹出底部菜单功能【附源码下载】
Dec 09 Javascript
在NPM发布自己造的轮子的方法步骤
Mar 09 Javascript
微信小程序实现手势滑动效果
Aug 26 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
php字符串截取中文截取2,单字节截取模式
2007/12/10 PHP
谈谈 PHP7新增功能
2015/12/16 PHP
基于PHP实现简单的随机抽奖小程序
2016/01/05 PHP
php Session无效分析资料整理
2016/11/29 PHP
php swoole多进程/多线程用法示例【基于php7nts版】
2019/08/12 PHP
javascript CSS画图之基础篇
2009/07/29 Javascript
跟我一起学写jQuery插件开发方法(附完整实例及下载)
2010/04/01 Javascript
基于jQuery实现表单提交验证
2014/11/24 Javascript
Angularjs基础知识及示例汇总
2015/01/22 Javascript
jQuery图片特效插件Revealing实现拉伸放大
2015/04/22 Javascript
png在IE6 下无法透明的解决方法汇总
2015/05/21 Javascript
JS数组合并push与concat区别分析
2015/12/17 Javascript
JS实现点击登录弹出窗口同时背景色渐变动画效果
2016/03/25 Javascript
vue.js加载新的内容(实例代码)
2017/06/01 Javascript
详解vue-router和vue-cli以及组件之间的传值
2017/07/04 Javascript
浅谈VUE监听窗口变化事件的问题
2018/02/24 Javascript
Vue匿名插槽与作用域插槽的合并和覆盖行为
2019/04/22 Javascript
jquery插件开发模式实例详解
2019/07/20 jQuery
零基础写python爬虫之抓取糗事百科代码分享
2014/11/06 Python
在Python中关于中文编码问题的处理建议
2015/04/08 Python
200行自定义python异步非阻塞Web框架
2017/03/15 Python
如何安装多版本python python2和python3共存以及pip共存
2018/09/18 Python
python RC4加密操作示例【测试可用】
2019/09/26 Python
使用Rasterio读取栅格数据的实例讲解
2019/11/26 Python
Python操作注册表详细步骤介绍
2020/02/05 Python
Django用户登录与注册系统的实现示例
2020/06/03 Python
实习医生自我评价
2013/09/22 职场文书
大学同学聚会邀请函
2014/01/29 职场文书
个人自我评价范文
2014/02/05 职场文书
政府采购方案
2014/06/12 职场文书
2014年教师节国旗下讲话稿
2014/09/10 职场文书
八月一日观后感
2015/06/10 职场文书
矛盾论读书笔记
2015/06/29 职场文书
室外天线与收音机天线杆接合方法
2022/04/05 无线电
Python语法学习之进程的创建与常用方法详解
2022/04/08 Python
Alexa停服!网站排名将何去何从?目前还没有替代品。
2022/04/15 杂记