一、流式布局
1、 什么是流式布局
流式布局就是百分比布局,通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容向两侧填充,同时会设定最小宽度和最大宽度,适用于图片比较多的首页、门户、电商等。
在这里我们以京东的M站为例进行说明:
可以看到,在京东各个模块的主容器中,都设置了最大最小宽度和宽度100%,而在导航区块中,由于一行有5个小区块,所以设置了宽度为20%,使得小区块也能达到自适应的效果。
2、 viewport
在移动端用来承载网页的这个区域就是我们的视觉窗口
viewport
,这个区域可以设置高度宽度,可以按比例放大缩小,而且能设置是否允许用户自行缩放。
- width:设置的是
viewport
宽度,可以设置device-width
特殊值。 - initial-scale:初始缩放比,大于0的数字,一般设置为1.0。
- maximum-scale:最大缩放比,大于0的数字。
- minimum-scale:最小缩放比,大于0的数字。
- user-scalable:用户是否可以缩放,yes或no(1或0)。
<!--视口标签通可以使用 meta:vp + tab 来快速生成,通常我们可以设置为下边这样。-->
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=0"/>
二 、 移动端常见事件
1、touch事件
- touchstart:当手指触碰屏幕时候发生。不管当前有多少只手指。
- touchmove:当手指在屏幕上滑动时连续触发。通常我们再滑屏页面,会调用
event
的preventDefault()
可以阻止默认情况的发生:阻止页面滚动。 - touchend:当手指离开屏幕时触发。
- touchcancel:系统停止跟踪触摸时候会触发。例如在触摸过程中突然页面
alert()
一个提示框,此时会触发该事件,这个事件比较少用。
触摸事件的响应顺序:
ontouchstart --> ontouchmove --> ontouchend --> onclick(300ms延时)。
2、event事件
- originalEvent:(原生事件)是
jquery
封装的事件。� - targetTouches:目标元素的所有当前触摸。
- changedTouches:页面上最新更改的所有触摸。
- touches:页面上的所有触摸。注意:在
touchend
事件的时候event
只会记录changedtouches
。
三、响应式开发
1、什么是响应式开发
在移动互联日益成熟的时候,我们在桌面浏览器上开发的网页已经无法满足移动设备的阅读。
通常的做法是针对移动端单独做一套特定的版本。
但是如果终端越来越多那么你需要开发的版本就会越来越多(大屏移动设备普及)。
那么
Ethan Marcotte
在2010年5月份提出的一个概念,简而言之,就是一个网站能够兼容多个终端。
2、响应式开发的前景
现在的移动设备屏幕越来越大。
越来越多的设计师也采用了这种设计。
在新建站的一些网站现在普遍采用的响应式开发。
那么在前端开发当中也是一项必备的技能。
3、 响应式开发的原理
CSS3中的
Media Query
(媒介查询),通过查询screen
的宽度来指定某个宽度区间的网页布局。
- 超小屏幕:768px以下(移动设备)。
- 小屏设备:768px-992px。
- 中等屏幕:992px-1200px。
- 宽屏设备:1200px以上。
四、Bootstrap框架
1、Bootstrap简介
- 官方网站
- Bootstrap中文网
- 它是由
Twitter
的设计师Mark Otto
和Jacob Thornton
合作开发,是一个CSS/HTML
框架。它提供了优雅的HTML
和CSS
规范,它即是由动态CSS
语言Less
写成。 -
Bootstrap
是基于HTML5
和CSS3
开发的,它在jQuery
的基础上进行了更为个性化和人性化的完善,形成一套自己独有的网站风格,并兼容大部分jQuery
插件。 -
Bootstrap
中包含了丰富的Web
组件,根据这些组件,可以快速的搭建一个漂亮、功能完备的网站。其中包括以下组件:下拉菜单、按钮组、按钮下拉菜单、导航、导航条、路径导航、分页、排版、缩略图、警告对话框、进度条、媒体对象等。
2、Bootstrap常用样式
- container类:用于定义一个固定宽度且居中的版心。
1 <div class="topbar">
2 <div class="container">
3 <!--
4 此处的代码会显示在一个固定宽度且居中的容器中
5 该容器的宽度会跟随屏幕的变化而变化
6 -->
7 </div>
8 </div>
栅格系统:Bootstrap
中定义了一套响应式的网格系统,其使用方式就是将一个容器划分成12列,然后通过col-xx-xx
的类名控制每一列的占比。
- row类:
- 因为每一个列默认有一个15px的左右外边距。
-
row
类的一个作用就是通过左右-15px屏蔽掉这个边距。
<div class="container">
<div class="row"></div>
</div>
col-xx-x类:
- 第一个连接符后边写屏幕尺寸,有
xs
超小屏幕 手机(<768px)、sm
小屏幕 平板 (≥768px)、md
中等屏幕 桌面显示器(≥992px)、lg
大屏幕 大桌面显示器 (≥1200px)四种。 - 第二个连接符后边表示对应的份数,占12份中的几份
1 <div class="row">
2 <div class="col-md-2 text-center"></div>
3 <div class="col-md-5 text-center"></div>
4 <div class="col-md-2 text-center"></div>
5 <div class="col-md-3 text-center"></div>
6 </div>
hidden类:设置在不同的屏幕下隐藏。
<div class="hidden-xs,hidden-sm,hidden-md,hidden-lg">
</div>
text-xx类:设置文字的对齐方式。
text-center 文本居中
text-left 文本左对齐
text-right 文本右对齐
pull-xx类:设置浮动。
pull-left 左浮动类
pull-right 右浮动类
- center-block类:让一个固定宽度的元素居中。
3、字体图标
- 字体图标:
@font-face {
font-family: 'XXX';
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');
}
字体文件格式:
eot:embedded-opentype
svg:svg
ttf:truetype
woff:woff
4、轮播图插件 Carousel
- 基本的轮播图实现:
1 <!--
2 以下容器就是整个轮播图组件的整体,
3 注意该盒子必须加上 class="carousel slide" data-ride="carousel" 表示当前是一个轮播图
4 bootstrap.js会自动为当前元 素添加图片轮播的特效
5 -->
6 <div id="轮播图的ID" class="carousel slide" data-ride="carousel">
7 <!-- ol标签是图片轮播的控制点 -->
8 <ol class="carousel-indicators">
9 <!--
10 每一个li就是一个单独的控制点
11 data-target属性就是指定当前控制点控制的是哪一个轮播图,其目的是如果界面上有多个轮播图,便于区分到底控制哪一个
12 data-slide-to属性是指当前的li元素绑定的是第几个轮播项
13 注意,默认必须给其中某个li加上active,展示的时候就是焦点项目
14 -->
15 <li data-target="#轮播图的ID" data-slide-to="0" class="active"></li>
16 <li data-target="#轮播图的ID" data-slide-to="1"></li>
17 <!-- ...更多的 -->
18 </ol>
19 <!--
20 .carousel-inner是所有轮播项的容器盒子,
21 注意role="listbox"代表当前div是一个列表盒子,作用就是给当前div添加一个语义
22 -->
23 <div class="carousel-inner" role="listbox">
24 <!-- 每一个.item就是单个轮播项目,注意默认要给第一个轮播项目加上active,表示为焦点 -->
25 <div class="item active">
26 <!-- 轮播项目中展示的图片 -->
27 ![](example.jpg)
28 <div class="carousel-caption">
29 <!-- 标题或说明性文字,如果不需要,直接删除当前div.carousel-caption -->
30 </div>
31 </div>
32 <div class="item">
33 <!-- ... -->
34 </div>
35 <!-- ... -->
36 </div>
37 <!-- 图片轮播上左右两个控制按钮,分别点击可以滚动到上一张和下一张 -->
38 <!-- 此处需要注意的是 该a链接的href属性必须指向需要控制的轮播图ID -->
39 <!-- 另外a链接中的data-slide="prev"代表点击该链接会滚到上一张,如果设置为next的话则相反 -->
40 <a class="left carousel-control" href="#轮播图的ID" role="button" data-slide="prev">
41 <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
42 <span class="sr-only">上一张</span>
43 </a>
44 <a class="right carousel-control" href="#轮播图的ID" role="button" data-slide="next">
45 <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
46 <span class="sr-only">下一张</span>
47 </a>
48 </div>