Bootstrap整体框架之CSS12栅格系统
发布时间 - 2026-01-10 21:51:04 点击率:次1.整体架构
BootStrap框架公共六个部分:(css组件和js插件是其表现形式,其余的是基础支撑平台)
表现形式
CSS组件
JS插件
基础支撑平台
CSS12栅格系统
基础布局组件
jQuery
响应式设计
1.1 CSS12栅格系统
12栅格系统是BootStrap的核心功能,也是响应式设计核心理念的一个实现方式。
1.1.1 实现原理
栅格布局原理:定义容器大小,平分12分,在调整内外边距,最后结合媒体查询,制作出强大响应式的栅格系统。
1.最外层的边框,伴随着响应式思想,区分了四种类型浏览器,像素分界点768px、992px、1200px
2.第二层的边框,即.container样式容器,针对四种浏览器宽度不一样,值是自动、750px、970px、1170px
//源码
.container {
padding-right: 15px;
padding-left: 15px;
margin-right: auto;
margin-left: auto;
}
@media (min-width: 768px) {
.container {
width: 750px;
}
}
@media (min-width: 992px) {
.container {
width: 970px;
}
}
@media (min-width: 1200px) {
.container {
width: 1170px;
}
}
3.1号横条,左内边距和右内边距是15px,是12个col-lg-1,没有row,则会
//源码
.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 {
position: relative;
min-height: 1px;
padding-right: 15px;
padding-left: 15px;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<!-- Bootstrap从3.0版本开始全面支持移动平台,贯彻移动先行宗旨 -->
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Bootstrap 101 Template</title>
<!-- Bootstrap -->
<link href="bootstrap-3.3.7-dist/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
<div class="container" style="border:1px solid black">
<div class="col-lg-1" style="border:1px solid black">col-lg-1</div>
<div class="col-lg-1" style="border:1px solid black">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1" style="border:1px solid black">col-lg-1</div>
</div>
<!-- bootstrap是基于jQuery-->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script src="bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
</body>
</html>
4.2号横条,也就是row容器的定义,margin-left和margin-right都是-15px,组合row和列后,形成3号横条的效果,也就是左右宽度用满的效果。
//源码
.row {
margin-right: -15px;
margin-left: -15px;
}
有row,则会没边距
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<!-- Bootstrap从3.0版本开始全面支持移动平台,贯彻移动先行宗旨 -->
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>Bootstrap 101 Template</title>
<!-- Bootstrap -->
<link href="bootstrap-3.3.7-dist/css/bootstrap.min.css" rel="stylesheet">
</head>
<body>
<div class="container" style="border:1px solid black">
<div class="row">
<div class="col-lg-1" style="border:1px solid black">col-lg-1</div>
<div class="col-lg-1" style="border:1px solid black">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1">col-lg-1</div>
<div class="col-lg-1" style="border:1px solid black">col-lg-1</div>
</div>
</div>
<!-- bootstrap是基于jQuery-->
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script src="bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
</body>
</html>
1.1.2 基本用法
1.列组合
<div class="container" style="border:1px solid black">
<div class="row">
<div class="col-lg-8" style="border:1px solid black">col-lg-8</div>
<div class="col-lg-4" style="border:1px solid black">col-lg-4</div>
</div>
<div class="row">
<div class="col-lg-6" style="border:1px solid black">col-lg-6</div>
<div class="col-lg-6" style="border:1px solid black">col-lg-6</div>
</div>
</div>
实现很简单,就是涉及了两个CSS特性:左浮动和宽度百分比
//源码
@media (min-width: 1200px) {
.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;
}
.col-lg-12 {
width: 100%;
}
.col-lg-11 {
width: 91.66666667%;
}
.col-lg-10 {
width: 83.33333333%;
}
.col-lg-9 {
width: 75%;
}
.col-lg-8 {
width: 66.66666667%;
}
.col-lg-7 {
width: 58.33333333%;
}
.col-lg-6 {
width: 50%;
}
.col-lg-5 {
width: 41.66666667%;
}
.col-lg-4 {
width: 33.33333333%;
}
.col-lg-3 {
width: 25%;
}
.col-lg-2 {
width: 16.66666667%;
}
.col-lg-1 {
width: 8.33333333%;
}
}
2.列偏移
我们不想让相邻的列挨在一起,则利用栅格系统的列偏移.col-xs(sm,md,lg)-offset-* 功能来实现,不必再定义margin
<div class="row"> <div class="col-lg-8 col-lg-offset-2" style="border:1px solid black">col-lg-8 col-lg-offset-2</div> <div class="col-lg-2 col-lg-offset-2" style="border:1px solid black">col-lg-2 col-lg-offset-2</div> </div>
//源码
.col-lg-offset-12 {
margin-left: 100%;
}
.col-lg-offset-11 {
margin-left: 91.66666667%;
}
.col-lg-offset-10 {
margin-left: 83.33333333%;
}
.col-lg-offset-9 {
margin-left: 75%;
}
.col-lg-offset-8 {
margin-left: 66.66666667%;
}
.col-lg-offset-7 {
margin-left: 58.33333333%;
}
.col-lg-offset-6 {
margin-left: 50%;
}
.col-lg-offset-5 {
margin-left: 41.66666667%;
}
.col-lg-offset-4 {
margin-left: 33.33333333%;
}
.col-lg-offset-3 {
margin-left: 25%;
}
.col-lg-offset-2 {
margin-left: 16.66666667%;
}
.col-lg-offset-1 {
margin-left: 8.33333333%;
}
.col-lg-offset-0 {
margin-left: 0;
}
3.列嵌套
栅格系统也支持列嵌套,也就是一个列中可以在声明一个或者多个行.内部嵌套的row宽度是100%,就是当前外部列的宽度
<div class="row">
<div class="col-lg-8" style="border:1px solid black">col-lg-8</div>
<div class="col-lg-4" style="border:1px solid black">
<div class="row">
<div class="col-lg-6">col-lg-6</div>
<div class="col-lg-6">col-lg-6</div>
</div>
</div>
</div>
4.列排序
列排序就是改变列的方向,也就是改变左右浮动,并且设置浮动的距离。可以通过.col-xs(sm,md,lg)-pull(push)-*
所有列设置的都是左浮动,通过设置left和right来实现定位显示。push则设置left,pull则设置right
其实只是利用了float,left,right三个属性就实现了这种效果
//源码
.col-lg-pull-12 {
right: 100%;
}
.col-lg-pull-11 {
right: 91.66666667%;
}
.col-lg-pull-10 {
right: 83.33333333%;
}
.col-lg-pull-9 {
right: 75%;
}
.col-lg-pull-8 {
right: 66.66666667%;
}
.col-lg-pull-7 {
right: 58.33333333%;
}
.col-lg-pull-6 {
right: 50%;
}
.col-lg-pull-5 {
right: 41.66666667%;
}
.col-lg-pull-4 {
right: 33.33333333%;
}
.col-lg-pull-3 {
right: 25%;
}
.col-lg-pull-2 {
right: 16.66666667%;
}
.col-lg-pull-1 {
right: 8.33333333%;
}
.col-lg-pull-0 {
right: auto;
}
.col-lg-push-12 {
left: 100%;
}
.col-lg-push-11 {
left: 91.66666667%;
}
.col-lg-push-10 {
left: 83.33333333%;
}
.col-lg-push-9 {
left: 75%;
}
.col-lg-push-8 {
left: 66.66666667%;
}
.col-lg-push-7 {
left: 58.33333333%;
}
.col-lg-push-6 {
left: 50%;
}
.col-lg-push-5 {
left: 41.66666667%;
}
.col-lg-push-4 {
left: 33.33333333%;
}
.col-lg-push-3 {
left: 25%;
}
.col-lg-push-2 {
left: 16.66666667%;
}
.col-lg-push-1 {
left: 8.33333333%;
}
.col-lg-push-0 {
left: auto;
}
1.1.3 响应式栅格
已知col-xs-* col-sm-* col-md-* col-lg-*
1.跨设备组合定义
一种样式(比如col-md-9)在其定义的尺寸范围以外是不起作用的,比如,在小型或者大型屏幕上,所有带有md的样式都不会生效。我们可以在一个元素上应用不同的样式,以适配不同尺寸的屏幕。
<div class="container" style="border:1px solid black">
<div class="row">
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div1 col-xs-6 col-sm-3 qwerwrgwefhsdgfsdfg</div>
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div2 col-xs-6 col-sm-3</div>
<div class="clearfix visible-xs"></div>
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div3 col-xs-6 col-sm-3</div>
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div4 col-xs-6 col-sm-3</div>
</div>
</div>
如图,由于div3换行时,但div1过高,则div3就右边紧挨着显示了。
所以需要利用clearfix样式清除浮动,但前提是在超小型屏幕上才显示(用visible-xs控制)
<div class="container" style="border:1px solid black">
<div class="row">
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div1 col-xs-6 col-sm-3 qwerwrgwefhsdgfsdfg</div>
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div2 col-xs-6 col-sm-3</div>
<div class="clearfix visible-xs"></div>
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div3 col-xs-6 col-sm-3</div>
<div class="col-xs-6 col-sm-3" style="border:1px solid black"> div4 col-xs-6 col-sm-3</div>
</div>
</div>
//源代码
.clearfix:before,
.clearfix:after,
.dl-horizontal dd:before,
.dl-horizontal dd:after,
.container:before,
.container:after,
.container-fluid:before,
.container-fluid:after,
.row:before,
.row:after,
.form-horizontal .form-group:before,
.form-horizontal .form-group:after,
.btn-toolbar:before,
.btn-toolbar:after,
.btn-group-vertical > .btn-group:before,
.btn-group-vertical > .btn-group:after,
.nav:before,
.nav:after,
.navbar:before,
.navbar:after,
.navbar-header:before,
.navbar-header:after,
.navbar-collapse:before,
.navbar-collapse:after,
.pager:before,
.pager:after,
.panel-body:before,
.panel-body:after,
.modal-header:before,
.modal-header:after,
.modal-footer:before,
.modal-footer:after {
display: table;
content: " ";
}
.clearfix:after,
.dl-horizontal dd:after,
.container:after,
.container-fluid:after,
.row:after,
.form-horizontal .form-group:after,
.btn-toolbar:after,
.btn-group-vertical > .btn-group:after,
.nav:after,
.navbar:after,
.navbar-header:after,
.navbar-collapse:after,
.pager:after,
.panel-body:after,
.modal-header:after,
.modal-footer:after {
clear: both;
}
//源代码
@media (max-width: 767px) {
.visible-xs {
display: block !important;
}
table.visible-xs {
display: table !important;
}
tr.visible-xs {
display: table-row !important;
}
th.visible-xs,
td.visible-xs {
display: table-cell !important;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# Bootstrap框架
# CSS12栅格系统
# Bootstrap每天必学之栅格系统(布局)
# Bootstrap布局之栅格系统详解
# Bootstrap自动适应PC、平板、手机的Bootstrap栅格系统
# 学习使用bootstrap3栅格系统
# BootStrap框架个人总结(bootstrap框架、导航条、下拉菜单、轮播广告carousel、
# 第五章之BootStrap 栅格系统
# Bootstrap入门书籍之(三)栅格系统
# Bootstrap栅格系统使用方法及页面调整变形的解决方法
# 浅析BootStrap栅格系统
# bootstrap栅格系统示例代码分享
# 都是
# 四种
# 横条
# 来实现
# 则会
# 源代码
# 表现形式
# 的是
# 是一个
# 是在
# 也就
# 多个
# 是基于
# 屏幕上
# 我们可以
# 可以通过
# 很简单
# 如图
# 想让
# 过高
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
百度浏览器网页无法复制文字怎么办 百度浏览器复制修复
Laravel怎么进行数据库事务处理_Laravel DB Facade事务操作确保数据一致性
Laravel怎么自定义错误页面_Laravel修改404和500页面模板
网站制作大概多少钱一个,做一个平台网站大概多少钱?
西安专业网站制作公司有哪些,陕西省建行官方网站?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
Laravel Blade模板引擎语法_Laravel Blade布局继承用法
Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验
如何快速使用云服务器搭建个人网站?
使用豆包 AI 辅助进行简单网页 HTML 结构设计
Laravel怎么集成Log日志记录_Laravel单文件与每日日志配置及自定义通道【详解】
jQuery validate插件功能与用法详解
Firefox Developer Edition开发者版本入口
android nfc常用标签读取总结
简历在线制作网站免费版,如何创建个人简历?
如何基于云服务器快速搭建个人网站?
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
EditPlus中的正则表达式实战(5)
html5如何实现懒加载图片_ intersectionobserver api用法【教程】
详解vue.js组件化开发实践
Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】
php读取心率传感器数据怎么弄_php获取max30100的心率值【指南】
Linux系统运维自动化项目教程_Ansible批量管理实战
实现点击下箭头变上箭头来回切换的两种方法【推荐】
千库网官网入口推荐 千库网设计创意平台入口
郑州企业网站制作公司,郑州招聘网站有哪些?
如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)
今日头条AI怎样推荐抢票工具_今日头条AI抢票工具推荐算法与筛选【技巧】
网站制作软件免费下载安装,有哪些免费下载的软件网站?
Laravel怎么使用Intervention Image库处理图片上传和缩放
网站制作价目表怎么做,珍爱网婚介费用多少?
如何生成腾讯云建站专用兑换码?
如何在阿里云虚拟服务器快速搭建网站?
常州企业网站制作公司,全国继续教育网怎么登录?
Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南
如何快速搭建高效WAP手机网站吸引移动用户?
Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转
Laravel中间件如何使用_Laravel自定义中间件实现权限控制
如何用5美元大硬盘VPS安全高效搭建个人网站?
如何用腾讯建站主机快速创建免费网站?
Laravel storage目录权限问题_Laravel文件写入权限设置
Angular 表单中正确绑定输入值以确保提交与验证正常工作
JavaScript实现Fly Bird小游戏
如何快速搭建二级域名独立网站?
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
Python文件异常处理策略_健壮性说明【指导】
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
如何在IIS7上新建站点并设置安全权限?
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布

