# Bootstrap ## 简介 ### 什么是Bootstrap? ![Bootstrap 官网](./images/cover.png) - 框架:库 lib library - jQuery作为一个框架来讲,提供一套比较便捷的操作DOM的方式 - 把大家都需要的功能预先写好到一些文件 这就是一个框架 - Bootstrap 让我们的 Web 开发更简单,更快捷; - 注意是 Bootstrap 不是 BootStrap!这是一个词,不是合成词,其含义为:n. 引导指令,引导程序 - Bootstrap 是当下最流行的前端框架(界面工具集); - 特点就是灵活简洁,代码优雅,美观大方; - 其目的是为了让 Web 开发更敏捷; - 是 Twitter 公司的两名前端工程师 Mark Otto 和 Jacob Thornton 在 2011 - 年发起的,并利用业余时间完成第一个版本的开发; ### 为什么使用Bootstarp? - 生态圈火,不断地更新迭代; - 提供一套美观大方地界面组件; - 提供一套优雅的 HTML+CSS 编码规范; - 让我们的 Web 开发更简单,更快捷; ### 注意: > 使用 Bootstrap 并不代表不用写 CSS 样式,而是不用写绝大多数大家都会用到的样式 ## 准备 ### 下载Bootstrap - https://github.com/twbs/bootstrap/releases/download/v3.3.6/bootstrap-3.3.6-dist.zip - https://github.com/twbs/bootstrap/releases/download/v4.0.0-alpha.2/bootstrap-4.0.0-alpha.2-dist.zip ### 安装Bootstrap ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>页面标题</title> <!-- 引入Bootstrap核心样式文件(必须) --> <link rel="stylesheet" href="css/bootstrap.min.css"> <!-- 引入Bootstrap默认主题样式(可选) --> <link rel="stylesheet" href="css/bootstrap.theme.min.css"> <!-- 你自己的样式或其他文件 --> <link rel="stylesheet" href="example.css"> </head> <body> <!-- 你的HTML结构...... --> <!-- 以下代码,如果不使用JS插件则不需要 --> <!-- 由于Bootstrap的JS插件依赖jQuery,so 引入jQuery --> <script src="js/jquery.min.js"></script> <!-- 引入所有的Bootstrap的JS插件 --> <script src="bootstrap.min.js"></script> <!-- 你自己的脚本文件 --> <script src="example.js"></script> </body> </html> ``` ### Bootstrap文档 - [官方文档](http://getbootstrap.com/) - [中文文档](http://v3.bootcss.com/) ### 基础的Bootstrap模板 ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <!-- The above 3 meta tags *must* come first in the head; any other head content must come *after* these tags --> <title>Bootstrap 101 Template</title> <!-- Bootstrap --> <link href="css/bootstrap.min.css" rel="stylesheet"> <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries --> <!-- WARNING: Respond.js doesn't work if you view the page via file:// --> <!--[if lt IE 9]> <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script> <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script> <![endif]--> </head> <body> <h1>Hello, world!</h1> <!-- jQuery (necessary for Bootstrap's JavaScript plugins) --> <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script> <!-- Include all compiled plugins (below), or include individual files as needed --> <script src="js/bootstrap.min.js"></script> </body> </html> ``` ### Compatible ```html <meta http-equiv="X-UA-Compatible" content="IE=edge"> ``` - 此属性为文档兼容模式声明,表示如果在IE浏览器下则使用最新的标准渲染当前文档 ### 视口 ```html <meta name="viewport" content="width=device-width, initial-scale=1"> ``` - 视口的作用:在移动浏览器中,当页面宽度超出设备,浏览器内部虚拟的一个页面容器,将页面容器缩放到设备这么大,然后展示 - 目前大多数手机浏览器的视口(承载页面的容器)宽度都是980; - 视口的宽度可以通过meta标签设置 - 此属性为移动端页面视口设置,当前值表示在移动端页面的宽度为设备的宽度,并且不缩放(缩放级别为1) + width:视口的宽度 + initial-scale:初始化缩放 + user-scalable:是否允许用户自行缩放(值:yes/no; 1/0) + minimum-scale:最小缩放,一般设置了用户不允许缩放,就没必要设置最小和最大缩放 + maximum-scale:最大缩放 ### 条件注释 - 条件注释的作用就是当判断条件满足时,就会执行注释中的HTML代码,不满足时会当做注释忽略掉 ### 第三方依赖 - [jQuery](https://github.com/jquery/jquery) > Bootstrap框架中的所有JS组件都依赖于jQuery实现 - [html5shiv](https://github.com/aFarkas/html5shiv) > 让低版本浏览器可以识别HTML5的新标签,如header、footer、section等 - [respond](https://github.com/scottjehl/Respond) > 让低版本浏览器可以支持CSS媒体查询功能 ## 建议以后在HTML中将脚步的引入放到页面最底下 ## mediaquery ```css @media (判断条件(针对于当前窗口的判断)){ /*这里的代码只有当判断条件满足时才会执行*/ } @media (min-width: 768px) and (max-width: 992px) { /*这里的代码只有当(min-width: 1280px)满足时才会执行*/ .container { width: 750px; } } ``` - 当使用min-width作为判断条件一定要从小到大,其原因是CSS从上往下执行 ## 基础CSS样式 - [概要](http://v3.bootcss.com/css/#overview) + - [预置排版样式](http://v3.bootcss.com/css/#type) + 统一预制标签样式 + - [按钮样式](http://v3.bootcss.com/css/#buttons) + - [表格样式](http://v3.bootcss.com/css/#tables) + - [表单样式](http://v3.bootcss.com/css/#forms) + - [图片样式](http://v3.bootcss.com/css/#images) + - [辅助工具类](http://v3.bootcss.com/css/#helper-classes) + - [代码样式](http://v3.bootcss.com/css/#code) + - [栅格系统](http://v3.bootcss.com/css/#grid) + __xs__ : 超小屏幕 手机 (<768px) + __sm__ : 小屏幕 平板 (≥768px) + __md__ : 中等屏幕 桌面显示器 (≥992px) + __lg__ : 大屏幕 大桌面显示器 (≥1200px) - [响应式工具类](http://v3.bootcss.com/css/#responsive-utilities) + __hidden-xx__ : 在某种屏幕下隐藏 + __visible-xx__ : 在某种屏幕尺寸下显示 ## 预置界面组件 - [导航](http://v3.bootcss.com/components/#nav) - [导航条](http://v3.bootcss.com/components/#navbar) - [面包屑导航](http://v3.bootcss.com/components/#breadcrumbs) - [下拉菜单](http://v3.bootcss.com/components/#dropdowns) - [按钮式下拉菜单](http://v3.bootcss.com/components/#btn-dropdowns) - [按钮组](http://v3.bootcss.com/components/#btn-groups) - [输入框组](http://v3.bootcss.com/components/#input-groups) - [警告框](http://v3.bootcss.com/components/#alerts) - [页头](http://v3.bootcss.com/components/#page-header) - [分页](http://v3.bootcss.com/components/#pagination) - [列表组](http://v3.bootcss.com/components/#list-group) - [面板](http://v3.bootcss.com/components/#panels) - [媒体对象](http://v3.bootcss.com/components/#media) - [进度条](http://v3.bootcss.com/components/#progress) - [Glyphicons](http://v3.bootcss.com/components/#glyphicons) - [标签](http://v3.bootcss.com/components/#labels) - [徽章](http://v3.bootcss.com/components/#badges) - [缩略图](http://v3.bootcss.com/components/#thumbnails) - [大屏幕](http://v3.bootcss.com/components/#jumbotron) - [嵌入内容](http://v3.bootcss.com/components/#responsive-embed) - [内嵌](http://v3.bootcss.com/components/#wells) ## JavaScript插件 ### JavaScript插件的依赖情况 ### 如何使用Javascript插件 ### 内置组件 - [模态对话框](http://v3.bootcss.com/javascript/#modals) - [下拉菜单](http://v3.bootcss.com/javascript/#dropdowns) - [滚动监听](http://v3.bootcss.com/javascript/#scrollspy) - [标签页](http://v3.bootcss.com/javascript/#tabs) - [工具提示](http://v3.bootcss.com/javascript/#tooltips) - [弹出框](http://v3.bootcss.com/javascript/#popovers) - [警告框](http://v3.bootcss.com/javascript/#alerts) - [按钮](http://v3.bootcss.com/javascript/#buttons) - [折叠面板](http://v3.bootcss.com/javascript/#collapse) - [轮播图](http://v3.bootcss.com/javascript/#carousel) - [吸顶效果](http://v3.bootcss.com/javascript/#affix) + data-spy="affix" + data-offset-top="什么位置出现" + data-offset-bottom="什么位置消失" ## 深度自定义 Bootstrap ### 在线自定义 - [官网在线](http://getbootstrap.com/customize/) - [中文网在线](http://v3.bootcss.com/customize/) ### 源码编译 ### LESS语言 - [官方文档](http://lesscss.org/)- [中文文档](http://lesscss.cn/)
# 微金所项目实战 ## 1. 搭建Bootstrap页面骨架及项目目录结构 ``` ├─ /weijinsuo/ ··················· 项目所在目录 └─┬─ /css/ ······················· 我们自己的CSS文件 ├─ /font/ ······················ 使用到的字体文件 ├─ /img/ ······················· 使用到的图片文件 ├─ /js/ ························ 自己写的JS脚步 ├─ /lib/ ······················· 从第三方下载回来的库【只用不改】 ├─ /favicon.ico ················ 站点图标 └─ /index.html ················· 入口文件 ``` ### 1.1.约定编码规范 #### 1.1.1.HTML约定 - 在head中引入必要的CSS文件,优先引用第三方的CSS,方便我们自己的样式覆盖 - 在body末尾引入必要的JS文件,优先引用第三方的JS,注意JS文件之间的依赖关系,比如bootstrap.js依赖jQuery,那就应该先引用jquery.js 然后引用bootstrap.js #### 1.1.2.CSS约定 - 除了公共级别样式,其余样式全部由 模块前缀 - 尽量使用 直接子代选择器, 少用间接子代 避免错杀 ### 1.2.HTML5文档结构 ```html <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>页面标题</title> </head> <body> </body> </html> ``` ### 1.3.Viewport设置 ```html <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0"> ``` > html中插入视口设置,可以通过emmet __meta:vp__ 插入 ### 1.4.浏览器兼容模式 ```html <meta http-equiv="X-UA-Compatible" content="IE=edge"> ``` > html中插入兼容模式设置,可以通过emmet __meta:compat__ 插入 ### 1.5.favicon(站点图标) ```html <link rel="shortcut icon" type="image/x-icon" href="favicon.ico"> ``` > html中插入图标链接,可以通过emmet __link:favicon__ 插入 ### 1.6.引入相应的第三方文件 ```html <link rel="stylesheet" href="bootstrap.css"> <link rel="stylesheet" href="my.css"> ... <script src="jquery.js"></script> <script src="bootstrap.js"></script> <script src="my.js"></script> ``` ### 1.7.在我们默认的样式表中将默认字体设置为: ```css body{ font-family: "Helvetica Neue", Helvetica, Microsoft Yahei, Hiragino Sans GB, WenQuanYi Micro Hei, sans-serif; } ``` ## 2.完成页面空结构 > 先划分好页面中的大容器,然后在具体看每一个容器中单独的情况 ```html <body> <!-- 头部区域 --> <header></header> <!-- /头部区域 --> <!-- 广告轮播 --> <section></section> <!-- /广告轮播 --> <!-- 特色介绍 --> <section></section> <!-- /特色介绍 --> <!-- 立即预约 --> <section></section> <!-- /立即预约 --> <!-- 产品推荐 --> <section></section> <!-- /产品推荐 --> <!-- 新闻列表 --> <section></section> <!-- /新闻列表 --> <!-- 合作伙伴 --> <section></section> <!-- /合作伙伴 --> <!-- 脚注区域 --> <footer></footer> <!-- /脚注区域 --> </body> ``` ## 3.构建顶部通栏 ```html <header> <div class="topbar"></div> </header> ``` ### 3.1.container类 - 用于定义一个固定宽度且居中的版心 ```html <div class="topbar"> <div class="container"> <!-- 此处的代码会显示在一个固定宽度且居中的容器中 该容器的宽度会跟随屏幕的变化而变化 --> </div> </div> ``` ### 3.2.栅格系统 - Bootstrap中定义了一套响应式的网格系统, - 其使用方式就是将一个容器划分成12列, - 然后通过col-xx-xx的类名控制每一列的占比 #### 3.2.1.row类 - 因为每一个列默认有一个15px的左右外边距 - row类的一个作用就是通过左右-15px屏蔽掉这个边距 ```html <div class="container"> <div class="row"></div> </div> ``` #### 3.2.2.col-*\*-\*类 - col-xs-[列数]:在超小屏幕下展示几份 - col-sm-[列数]:在小屏幕下展示几份 - col-md-[列数]:在中等屏幕下展示几份 - col-lg-[列数]:在大屏幕下展示几份 - __xs__ : 超小屏幕 手机 (<768px) - __sm__ : 小屏幕 平板 (≥768px) - __md__ : 中等屏幕 桌面显示器 (≥992px) - __lg__ : 大屏幕 大桌面显示器 (≥1200px) ```html <div class="row"> <div class="col-md-2 text-center"></div> <div class="col-md-5 text-center"></div> <div class="col-md-2 text-center"></div> <div class="col-md-3 text-center"></div> </div> ``` > 此处顶部通栏已经被划分成四列 > text-center的作用就是让内部内容居中显示 ### 3.2.字体图标 ```css @font-face { font-family: 'itcast'; src: url('../font/MiFie-Web-Font.eot') format('embedded-opentype'), url('../font/MiFie-Web-Font.svg') format('svg'), url('../font/MiFie-Web-Font.ttf') format('truetype'), url('../font/MiFie-Web-Font.woff') format('woff'); } [class^="icon-"], [class*=" icon-"] { /*注意上面选择器中间的空格*/ /*我们使用的名为itcast的字体就是上面的@font-face的方式声明的*/ font-family: itcast; font-style: normal; } .icon-mobilephone::before{ content: '\e908'; } ``` ```html <div class="col-md-2 text-center"> <a class="mobile-link" href="#"> <i class="icon-mobile"></i> <span>手机微金所</span> <!-- 这里使用的是bootstrap中的字体图标 --> <i class="glyphicon glyphicon-chevron-down"></i> <img src="..." alt=""> </a> </div> ``` #### 字体文件格式 - eot : embedded-opentype - svg : svg - ttf : truetype - woff : woff ### 3.4.hover图片展示 ```css .mobile-link:hover > img { display: block; } ``` ### 3.5.按钮样式生成 - http://blog.koalite.com/bbg/ - 可以通过界面生成一个新的按钮样式 ```css .btn-itcast { color: #ffffff; background-color: #E92322; border-color: #DB3B43; } .btn-itcast:hover, .btn-itcast:focus, .btn-itcast:active, .btn-itcast.active, .open .dropdown-toggle.btn-itcast { color: #ffffff; background-color: #E92322; border-color: #DB3B43; } .btn-itcast:active, .btn-itcast.active, .open .dropdown-toggle.btn-itcast { background-image: none; } .btn-itcast.disabled, .btn-itcast[disabled], fieldset[disabled] .btn-itcast, .btn-itcast.disabled:hover, .btn-itcast[disabled]:hover, fieldset[disabled] .btn-itcast:hover, .btn-itcast.disabled:focus, .btn-itcast[disabled]:focus, fieldset[disabled] .btn-itcast:focus, .btn-itcast.disabled:active, .btn-itcast[disabled]:active, fieldset[disabled] .btn-itcast:active, .btn-itcast.disabled.active, .btn-itcast[disabled].active, fieldset[disabled] .btn-itcast.active { background-color: #E92322; border-color: #DB3B43; } .btn-itcast .badge { color: #E92322; background-color: #ffffff; } ``` ### 3.5小屏幕隐藏 ```html <div class="topbar hidden-xs hidden-sm"></div> ``` 或者 ```html <div class="topbar visible-md visible-lg"></div> ``` - __hidden-xx__ : 在某种屏幕下隐藏 - __visible-xx__ : 在某种屏幕尺寸下显示 ## 4.导航通栏 - 在使用了boostrap过后,大多数界面元素都是通过bootstrap提供好的界面组件修改得来 ```html <nav class="navbar navbar-itcast navbar-static-top"> <div class="container"> <div class="navbar-header"> <button id="btn" type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#nav_list" aria-expanded="false"> <span class="sr-only">切换菜单</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> <a class="navbar-brand" href="#"> <i class="icon-icon"></i> <i class="icon-logo"></i> </a> </div> <div id="nav_list" class="collapse navbar-collapse"> <ul class="nav navbar-nav"> <li class="active"><a href="#">我要投资</a></li> <li><a href="#">我要借款</a></li> <li><a href="#">平台介绍</a></li> <li><a href="#">新手专区</a></li> <li><a href="#">最新动态</a></li> <li><a href="#">微论坛</a></li> </ul> <ul class="nav navbar-nav navbar-right hidden-sm"> <li><a href="#">个人中心</a></li> </ul> </div> </div> </nav> ``` ### 4.1.Bootstrap扩展 - 通过bootstrap文档对导航条样式的设置发现,其实本身是有一个类似于主题的概念 - navbar-default:默认的外观 - navbar-inverse:暗色背景的样式 - 所以我们希望可以通过自定义一套完整的风格: + navbar-itcast ```css .navbar-itcast{ ... } ...具体代码参考navbar-default实现即可 ``` ### 4.2.品牌logo - 任然使用字体图标 ### 4.3.菜单行高调整 - 默认样式中菜单的行高为20px,我们可以调整为自己想要的高度 - 一般都是通过自己的样式去覆盖 ## 5.轮播图 ### 5.1.Bootstrap JS插件使用 > 对于Bootstrap的JS插件,我们只需要将文档实例中的代码粘到我们自己的代码中 > 让后作出相应的样式调整 #### 5.1.1.Bootstrap中轮播图插件叫作Carousel #### 5.1.2.基本的轮播图实现 ```html <!-- 以下容器就是整个轮播图组件的整体, 注意该盒子必须加上 class="carousel slide" data-ride="carousel" 表示当前是一个轮播图 bootstrap.js会自动为当前元素添加图片轮播的特效 --> <div id="轮播图的ID" class="carousel slide" data-ride="carousel"> <!-- ol标签是图片轮播的控制点 --> <ol class="carousel-indicators"> <!-- 每一个li就是一个单独的控制点 data-target属性就是指定当前控制点控制的是哪一个轮播图,其目的是如果界面上有多个轮播图,便于区分到底控制哪一个 data-slide-to属性是指当前的li元素绑定的是第几个轮播项 注意,默认必须给其中某个li加上active,展示的时候就是焦点项目 --> <li data-target="#轮播图的ID" data-slide-to="0" class="active"></li> <li data-target="#轮播图的ID" data-slide-to="1"></li> <!-- ...更多的 --> </ol> <!-- .carousel-inner是所有轮播项的容器盒子, 注意role="listbox"代表当前div是一个列表盒子,作用就是给当前div添加一个语义 --> <div class="carousel-inner" role="listbox"> <!-- 每一个.item就是单个轮播项目,注意默认要给第一个轮播项目加上active,表示为焦点 --> <div class="item active"> <!-- 轮播项目中展示的图片 --> <img src="example.jpg" alt="示例图片"> <div class="carousel-caption"> <!-- 标题或说明性文字,如果不需要,直接删除当前div.carousel-caption --> </div> </div> <div class="item"> <!-- ... --> </div> <!-- ... --> </div> <!-- 图片轮播上左右两个控制按钮,分别点击可以滚动到上一张和下一张 --> <!-- 此处需要注意的是 该a链接的href属性必须指向需要控制的轮播图ID --> <!-- 另外a链接中的data-slide="prev"代表点击该链接会滚到上一张,如果设置为next的话则相反 --> <a class="left carousel-control" href="#轮播图的ID" role="button" data-slide="prev"> <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span> <span class="sr-only">上一张</span> </a> <a class="right carousel-control" href="#轮播图的ID" role="button" data-slide="next"> <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span> <span class="sr-only">下一张</span> </a> </div> ``` #### 5.1.3.由于轮播图片超宽造成的影响 - 美工为了在不同屏幕下更好地展示将图片两边做的非常宽,但是我们大多数情况的页面宽度都无法满足这样的图片宽度 - 而且Bootstrap的样式中默认将图片的max-width设置为100%; - 造成界面图片缩放 - 想在一个较小屏幕下展示一个超宽的图片,并让图片居中显示 + 两种办法: * 换用背景图的方式,background-position: center center; * 使img元素绝对定位,left:50%,margin-left: -width/2 ### 5.2.background使用 - 将容器的高度固定(410px) - 将轮播图改为背景显示 - 由于可能图片的高度不一定是410px - 所以需要设置css3中的background-size #### 5.2.1.background-size - length + 如 background-size: 100px 100px,将背景图固定到多大尺寸 - percentage + 如 background-size: 90% 90%,以百分比的形式设置背景大小 - cover + 1.背景图片等比例缩放 + 2.让背景图相对较小边放大到目标容器大小结束 * 如:一张100\*200的背景图放到一个300\*400的盒子中,最终背景图片的大小是300\*600 * 因为背景图的较小边为100,将100放大到目标容器300的宽度,放大了3倍,最终结果300\*600 - contain + 1.背景图片等比例缩放 + 2.让背景图相对较大边放大到目标容器大小结束 * 如:一张100\*200的背景图放到一个300\*400的盒子中,最终背景图片的大小是200\*400 * 因为背景图的较大边为200,将200放大到目标容器400的高度,放大了2倍,最终结果200\*400 ##### demo ###### cover <div style="width: 400px;height: 200px;border:1px dashed #c0c0c0;background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9InllcyI/PjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB3aWR0aD0iMjQyIiBoZWlnaHQ9IjIwMCIgdmlld0JveD0iMCAwIDI0MiAyMDAiIHByZXNlcnZlQXNwZWN0UmF0aW89Im5vbmUiPjwhLS0KU291cmNlIFVSTDogaG9sZGVyLmpzLzEwMCV4MjAwCkNyZWF0ZWQgd2l0aCBIb2xkZXIuanMgMi42LjAuCkxlYXJuIG1vcmUgYXQgaHR0cDovL2hvbGRlcmpzLmNvbQooYykgMjAxMi0yMDE1IEl2YW4gTWFsb3BpbnNreSAtIGh0dHA6Ly9pbXNreS5jbwotLT48ZGVmcz48c3R5bGUgdHlwZT0idGV4dC9jc3MiPjwhW0NEQVRBWyNob2xkZXJfMTUxOWU5ZmNjZDAgdGV4dCB7IGZpbGw6I0FBQUFBQTtmb250LXdlaWdodDpib2xkO2ZvbnQtZmFtaWx5OkFyaWFsLCBIZWx2ZXRpY2EsIE9wZW4gU2Fucywgc2Fucy1zZXJpZiwgbW9ub3NwYWNlO2ZvbnQtc2l6ZToxMnB0IH0gXV0+PC9zdHlsZT48L2RlZnM+PGcgaWQ9ImhvbGRlcl8xNTE5ZTlmY2NkMCI+PHJlY3Qgd2lkdGg9IjI0MiIgaGVpZ2h0PSIyMDAiIGZpbGw9IiNFRUVFRUUiLz48Zz48dGV4dCB4PSI4OS44NTkzNzUiIHk9IjEwNS4xIj4yNDJ4MjAwPC90ZXh0PjwvZz48L2c+PC9zdmc+');background-repeat:no-repeat;background-size: cover;"></div> ###### contain <div style="width: 400px;height: 200px;border:1px dashed #c0c0c0;background-image: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9InllcyI/PjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB3aWR0aD0iMjQyIiBoZWlnaHQ9IjIwMCIgdmlld0JveD0iMCAwIDI0MiAyMDAiIHByZXNlcnZlQXNwZWN0UmF0aW89Im5vbmUiPjwhLS0KU291cmNlIFVSTDogaG9sZGVyLmpzLzEwMCV4MjAwCkNyZWF0ZWQgd2l0aCBIb2xkZXIuanMgMi42LjAuCkxlYXJuIG1vcmUgYXQgaHR0cDovL2hvbGRlcmpzLmNvbQooYykgMjAxMi0yMDE1IEl2YW4gTWFsb3BpbnNreSAtIGh0dHA6Ly9pbXNreS5jbwotLT48ZGVmcz48c3R5bGUgdHlwZT0idGV4dC9jc3MiPjwhW0NEQVRBWyNob2xkZXJfMTUxOWU5ZmNjZDAgdGV4dCB7IGZpbGw6I0FBQUFBQTtmb250LXdlaWdodDpib2xkO2ZvbnQtZmFtaWx5OkFyaWFsLCBIZWx2ZXRpY2EsIE9wZW4gU2Fucywgc2Fucy1zZXJpZiwgbW9ub3NwYWNlO2ZvbnQtc2l6ZToxMnB0IH0gXV0+PC9zdHlsZT48L2RlZnM+PGcgaWQ9ImhvbGRlcl8xNTE5ZTlmY2NkMCI+PHJlY3Qgd2lkdGg9IjI0MiIgaGVpZ2h0PSIyMDAiIGZpbGw9IiNFRUVFRUUiLz48Zz48dGV4dCB4PSI4OS44NTkzNzUiIHk9IjEwNS4xIj4yNDJ4MjAwPC90ZXh0PjwvZz48L2c+PC9zdmc+');background-repeat:no-repeat;background-size: contain;"></div> ### 5.3.图片响应式 - 目的 + 各种终端都需要正常显示图片 + 移动端应该使用更小(体积)的图片 - 实现方式 + 将元素中直接设置的图片背景删除,换成两个data-属性(如:data-img-sm="小图路径",data-img-lg="大图路径") + 通过JS的方式获取屏幕的宽度; + 判断屏幕宽度是否小于一定的值(如:768) + 根据判断情况决定使用具体的大图还是小图 ```javascript // 获取屏幕宽度 var windowWidth = $(window).width(); // 判断屏幕属于大还是小 var isSmallScreen = windowWidth < 768; // 根据大小为界面上的每一张轮播图设置背景 // $('#main_ad > .carousel-inner > .item') // 获取到的是一个DOM数组(多个元素) $('#main_ad > .carousel-inner > .item').each(function(i, item) { // 因为拿到是DOM对象 需要转换 var $item = $(item); // var imgSrc = $item.data(isSmallScreen ? 'image-xs' : 'image-lg'); var imgSrc = isSmallScreen ? $item.data('image-xs') : $item.data('image-lg'); // 设置背景图片 $item.css('backgroundImage', 'url("' + imgSrc + '")'); }); ``` ### 5.4.window resize事件 - 由于上一步我们实现的过程是指在页面加载完成判断一次, - 当用户手动调整页面宽度过后没有及时发生变化, - 所以我们可以通过window的resize事件中重新完成以上操作来解决这个问题 ```javascript function 窗口变化后执行的函数名(){ // 具体的操作 } $(window).on('resize', 窗口变化后执行的函数名); ``` - 这个事件只会在窗口尺寸发生变化后执行,但是我们需要一开始时执行一次 ```javascript ... $(window).on('resize', 窗口变化后执行的函数名).trigger('resize'); ``` ### 5.5.小图片不需要使用背景的方式 - 小图如果还是使用背景的方式,当屏幕特别小时,效果很差 - 所以当使用小图时,改用img的方式 ```javascript // 因为我们需要小图时 尺寸等比例变化,所以小图时我们使用img方式 if (isSmallScreen) { $item.html('<img src="' + imgSrc + '" alt="" />'); } else { $item.empty(); } ``` - 按照目前的情况,如果是小图展示则不需要给容器加上410px的固定高度 - 所以我们可以通过CSS媒体查询的方式解决 ```css #main_ad > .carousel-inner > .item { background-repeat: no-repeat; background-position: center center; background-size: cover; } @media (min-width: 768px) { #main_ad > .carousel-inner > .item { height: 410px; } } #main_ad > .carousel-inner > .item > img { width: 100%; } ``` ## 6.网站特性 ### 6.1.网格系统 - 该板块当屏幕为中等尺寸时分为3列,较小屏幕是分为2列 - 所以使用网格系统划分 ```html <div class="col-sm-6 col-md-4"> <!-- ... --> </div> <!-- ... --> ``` ### 6.2.媒体对象样式 - 每一个小块的样式可以通过Bootstrap中的媒体对象样式实现 ```html <a href="#"> <div class="media"> <div class="media-left"> <i class="icon-uniE907"></i> </div> <div class="media-body"> <h4 class="media-heading">支付交易保障</h4> <p>银联支付全称保证支付安全</p> </div> </div> </a> ``` ### 6.3.响应式辅助类型 - 整个板块在超小屏幕下是隐藏起来的 + 只需要给当前板块加上hidden-xs的class ## 7.预约投标 ### 7.1.pull-left - 左边文字段落 ### 7.2.pull-right - 右边文字段落 ## 8.投资产品 ### 8.1.Tab选项卡 > 选项卡功能可以通过Bootstrap中提供的相应组件实现 > http://v3.bootcss.com/javascript/#tabs ```html <div class="container"> <!-- 所有的选项卡标签,每个标签点击分别对应面板展示出来 --> <ul class="nav nav-tabs" role="tablist"> <!-- 下面的li定义了一个选项卡的标签,其中a标签的href属性指向的就是对应要展开的面板ID aria-controls属性是说当前a链接控制的是哪个元素(注意此属性和功能无关,只是语义) 注意一定要给a标签加上data-toggle="tab",如果不加则boostrap无法知道这是一个选项卡标签,也就不会有相应的效果 --> <li role="presentation" class="active"><a href="#第一个标签的ID" aria-controls="第一个标签的ID" role="tab" data-toggle="tab">标签页1</a></li> <li role="presentation"><a href="#第二个标签的ID" aria-controls="第二个标签的ID" role="tab" data-toggle="tab">标签页2</a></li> </ul> <!-- Tab panes --> <div class="tab-content"> <!-- .tab-pane定义当前是一个tab面板,通过id和选项卡标签关联起来 --> <div role="tabpanel" class="tab-pane active" id="第一个标签的ID"> <!-- 标签展开后的内容 --> </div> <div role="tabpanel" class="tab-pane" id="第二个标签的ID">...</div> </div> </div> ``` ### 8.2.网格系统 - 和网站特色板块的网格系统定义一样 ### 8.3.::before ::after ```css .panel-czbk > .panel-heading::before, .panel-czbk > .panel-heading::after { content: ' '; width: 16px; height: 16px; border-radius: 8px; background-color: #f0f0f0; position: absolute; } .panel-czbk > .panel-heading::before { top: -8px; left: -8px; } .panel-czbk > .panel-heading::after { bottom: -8px; left: -8px; box-shadow: 0 2px 1px #ccc inset; } ``` ### 8.5.tooltip插件 - 注意,bootstrap中的tooltip插件必须通过js方式初始化 ### 8.6.选项卡标签横向滚动 1. 要给ul加一个容器,这个容器有横向滚动条 2. 动态设置ul的宽度,宽度是根据内容大小决定的 width= sum (li.width) ## 9.新闻资讯 ### 9.1.Tab选项卡 ### 9.2.响应式偏移 ## 10.合作伙伴 ### 10.1.相邻兄弟选择器 ## 11.登录对话框 ### 11.1模态框 ### 11.2表单样式 ## 12.导航吸顶 ### 12.1.affix组件 ## 13.深度自定义 ### 13.1.http://v3.bootcss.com/customize ### 13.2.通过 Less 文件修改 ## 14.version 4 http://www.cnblogs.com/micua/p/bootstrap-version4-alpha.html# Less ## Sass styuls > 一款比较流行的预处理CSS,支持变量、混合、函数、嵌套、循环等特点 > [官网](http://lesscss.org/) > [中文网](http://lesscss.cn/) > http://www.w3cplus.com/css/less ## 概要 ## 为什么要有预处理CSS CSS基本上是设计师的工具,不是程序员的工具。在程序员的眼里,CSS是很头痛的事情,它并不像其它程序语言,比如说PHP、Javascript等等,有自己的变量、常量、条件语句以及一些编程语法,只是一行行单纯的属性描述,写起来相当的费事,而且代码难易组织和维护。 很自然的,有人就开始在想,能不能给CSS像其他程序语言一样,加入一些编程元素,让CSS能像其他程序语言一样可以做一些预定的处理。这样一来,就有了“CSS预处器(CSS Preprocessor)”。 ## 什么是预处理CSS - CSS语言的超集,比CSS更丰满 - CSS预处理器定义了一种新的语言,其基本思想是,用一种专门的编程语言,为CSS增加了一些编程的特性,将CSS作为目标生成文件,然后开发者就只要使用这种语言进行编码工作。通俗的说,CSS预处理器用一种专门的编程语言,进行Web页面样式设计,然后再编译成正常的CSS文件,以供项目使用。CSS预处理器为CSS增加一些编程的特性,无需考虑浏览器的兼容性问题,例如你可以在CSS中使用变量、简单的逻辑程序、函数等等在编程语言中的一些基本特性,可以让你的CSS更加简洁、适应性更强、可读性更佳,更易于代码的维护等诸多好处。 CSS预处理器技术已经非常的成熟,而且也涌现出了很多种不同的CSS预处理器语言,比如说:Sass(SCSS)、LESS、Stylus、Turbine、Swithch CSS、CSS Cacheer、DT CSS等。如此之多的CSS预处理器,那么“我应该选择哪种CSS预处理器?”也相应成了最近网上的一大热门话题,在Linkedin、Twitter、CSS-Trick、知呼以及各大技术论坛上,很多人为此争论不休。相比过计我们对是否应该使用CSS预处理器的话题而言,这已经是很大的进步了。 到目前为止,在众多优秀的CSS预处理器语言中就属Sass、LESS和Stylus最优秀,讨论的也多,对比的也多。本文将分别从他们产生的背景、安装、使用语法、异同等几个对比之处向你介绍这三款CSS预处理器语言。相信前端开发工程师会做出自己的选择——我要选择哪款CSS预处理器。 ## 如何使用预处理Less ### less.js > 网页运行阶段解析LESS文件 #### 使用方式: ### less compiler > 开发阶段编译LESS文件成为CSS #### 使用方式: ##### 安装 - 安装Node.js - 安装less + 命令行执行:npm install -g less ##### 编译操作 ### 语法 #### 注释 ```less // 模板注释,这里的注释转换成CSS后将会删除 /* CSS 注释语法 转换为CSS后任然保留 */ ``` #### 定义变量 > 将需要重复使用或经常修改的值定义为变量,需要使用的地方引用 - less ```less @变量名: 变量值; @bgColor: #f5f5f5; body{ width: @变量名; background-color: @bgColor; } ``` - css ```css body{ width: 变量值; background-color: #f5f5f5; } ``` #### 嵌套 > 如果你在CSS中经常使用子代选择器,那LESS的嵌套语法使用起来非常Happy - less ```less .container { width: @containerWidth; > .row { height: 100%; a{ color: #f40; &:hover{ color: #f50; } } } div { width: 100px; .hello { background-color: #00f; } } } ``` - css ```css .container { width: 1024px; } .container > .row { height: 100%; } .container > .row a { color: #f40; } .container > .row a:hover { color: #f50; } .container div { width: 100px; } .container div .hello { background-color: #00f; } ``` #### Mixin ```less /* 定义一个类 */ .roundedCorners(@radius: 5px) { -moz-border-radius: @radius; -webkit-border-radius: @radius; border-radius: @radius; } /* 定义的类应用到另个一个类中 */ #header { .roundedCorners; } #footer { .roundedCorners(10px); } ``` #### Import > 我们可以在开发阶段将样式放到多个文件中,最后通过@import 的方式合并 - less ```less // main.less @btnColor: red; @import url('_buttom.less'); body{ width: 1024px; } // _buttom.less .btn{ color: @btnColor; } ``` - css ```less .btn{ color: red; } body{ width: 1024px; } ``` #### 函数 ##### 内置函数 - lighten:将一个颜色变亮 + lighten(#000, 10%); // #1a1a1a - darken:将一个颜色变暗 + darken(#000, 10%); // #e6e6e6 ##### 自定义函数等讲流行框架再说 ### 安装NodeJS
bootstrap Less
最新推荐文章于 2024-06-03 23:50:56 发布