二、响应式页面兼容移动端(其次):
①响应式开发(媒体查询)
原理:使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的。
响应式布局容器:响应式需要一个父级做为布局容器,来配合子级元素实现变化效果。
原理就是在不同屏幕下,通过媒体查询来改变这个布局容器的大小,再改变里面子元素的排列方式和大小,从而实现不同屏幕下,看到不同的页面布局和样式变化。
响应式布局的容器固定宽度:
- 大屏(>=1200px)宽度定为1170px
- 中屏(>=992px)宽度定为970px
- 小屏(>=768px)宽度定为750px
- 超小屏(100%)
②bootstrap
Bootstrap前端开发框架:
Bootstrap来自Twitter(推特),是目前最受欢迎的前端框架,是基于HTML、CSS、JAVASCRIPT的,它简洁灵活,使得Web开发更加快捷。(官网:http://getbootstrap.com/)
框架:顾名思义就是一套架构,它有一套比较完整的网页功能解决方案,而且控制权在框架本身,有预制样式库、组件和插件。使用者要按照框架所规定的某种规范进行开发。
优点:标准化的html+css编码规范。提供了一套简洁、直观、强悍的组件。有自己的生态圈,不断的更新迭代。让开发更简单,提高了开发的效率。
Bootstrap使用:
在现阶段我们还没有接确触JS相关课程,所以我们只考虑使用它的样式库。
控制权在框架本身,使用者要按照框架所规定的某种规范进行开发。
Bootstrap使用四步曲:1.创建文件夹结构 2.创建html骨架结构 3.引入相关样式文件 4.书写内容
布局容器:Bootstrap需要为页面内容和栅格系统包裹一个.container容器,Bootstarp预先定义好了这个类.container。它提供了两个作此用处的类。
Bootstrap栅格系统:
栅格系统(grid systems)也有人翻译为“网格系统”,它是指将页面布局划分为等宽的列,然后通过列数的定义来模块化页面布局。Bootstrap提供了一套响应式、移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列。 Bootstrap里面container宽度是固定的,但是不同屏幕下,container的宽度不同,我们再把container划分为12等份。
栅格选项参数:栅格系统用于通过一系列的行(row)与列(column)的组合来创建页面布局,你的内容就可以放入这些创建好的布局中。
超小屏幕(手机) <768px | 小屏设备(平板) >=768px | 中等屏幕(桌面) >=992pX | 宽屏设备(大桌面显示器) >=1200px | |
---|---|---|---|---|
.container 最大宽度 | 自动(100%) | 750px | 970px | 1170px |
类前缀 | .col-xs- | .col-sm- | .col-md- | .col-lg- |
列(column)数 | 12 | 12 | 12 | 12 |
- 行(row)必须放到container布局容器里面
- 我们实现列的平均划分,需要给列添加类前缀
- 列(column)大于12,多余的"列(column)"所在的元素将被作为一个整体另起一行排列
- 每一列默认有左右15像素的padding
- 可以同时为一列指定多个设备的类名,以便划分不同份数,例如 class="col-md-4 col-sm-6"
栅格系统-列嵌套:栅格系统内置的栅格系统将内容再次嵌套。简单理解就是一个列内再分成若干份小列。我们可以通过添加一个新的.row元素和一系列.col-sm-*元素到已经存在的.col-sm-*元素内
我们列嵌套最好加1个行row这样可以取消父元素的padding值而且高度自动和父级一样高
<!-列嵌套--> <div class="col-sm-4"> <div class="row"> <div class="col-sm-6">小列</div> <div class="col-sm-6">小列</div> </div> </div>
栅格系统-列偏移:使用.col-md-offset-*类可以将列向右侧偏移。这些类实际是通过使用*选择器为当前元素增加了左侧的边距(margin)。
<!-列偏移--> <div class="row"> <div class="col-lg-4">1</div> <div class="col-lg-4 col-lg-offset-4">2</div> </div>
栅格系统-列排序:通过使用.col-md-push-*和.col-md-pull-*类就可以很容易的改变列(column)的顺序。
<!--列排序--> <div class="row"> <div class="col-lg-4 col-lg-push-8">左</div> <div class="col-lg-8 col-lg-pull-4">右</div> </div>
响应式工具:为了加快对移动设备友好的页面开发工作,利用媒体查询功能,并使用这些工具类可以方便的针对不同设备展示或隐藏页面内容。
与之相反的,是visible-xs visible-sm visible-md visible-lg 是显示某个页面内容
类名 | 超小屏 | 小屏 | 中屏 | 大屏 |
---|---|---|---|---|
.hidden-xs | 隐藏 | 可见 | 可见 | 可见 |
.hidden-sm | 可见 | 隐藏 | 可见 | 可见 |
.hidden-md | 可见 | 可见 | 隐藏 | 可见 |
.hidden-lg | 可见 | 可见 | 可见 | 隐藏 |
Bootstrap其他(按钮、表单、表格)请参考Bootstrap文档。