## 一、实现动画的方式
![](http://cndpic.dodoke.com/6b4f4b64f757fde32d54aa1a9bd65352)
优先使用CSS3来实现动画,在不支持CSS3时候,
动画示例如下:
```
<button id="btn">start</button>
<div id="box" class="box"></div>
```
```
* {
padding: 0;
margin: 0;
}
.box {
width: 100px;
height: 100px;
background-color: red;
}
```
```
.box {
transition: transform 1s;
}
// 使用 CSS3 transition
var boxEl = document.getElementById('box'),
btnEl = document.getElementById('btn');
var dest = window.innerWidth - 100;
btnEl.addEventListener('click', function () {
move(boxEl, dest);
}, false);
function move(el, position) {
el.style.transform = 'translate3d(' + position +'px, 0, 0)';
}
```
```
// 或者使用 requestAnimationFrame
var requestAnimationFrame = window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.msRequestAnimationFrame ||
window.oRequestAnimationFrame ||
function (fn) {
setTimeout(fn, 16);
};
var boxEl = document.getElementById('box'),
btnEl = document.getElementById('btn');
var dest = window.innerWidth - 100,
speed = 10,
position = 0;
btnEl.addEventListener('click', function () {
requestAnimationFrame(step);
}, false);
function move(el, position) {
el.style.transform = 'translate3d(' + position +'px, 0, 0)';
}
function step() {
if (position < dest) {
position += speed;
move(boxEl, position);
requestAnimationFrame(step);
} else {
position = dest;
move(boxEl, position);
}
}
```
- 第一章:移动开发入门
- 第一节:概述
- 第二节:基础概念
- 第一课时:像素
- 第二课时:视口
- 第二章:Flex 布局
- 第一节:概述
- 第二节:容器属性
- 第一课时:flex-direction 属性
- 第二课时:flex-wrap 属性
- 第三课时:flex-flow 属性
- 第四课时:justify-content 属性
- 第五课时:align-items 属性
- 第六课时:align-content 属性
- 第三节:项目属性
- 第一课时:order 属性
- 第二课时:flex-grow 属性
- 第三课时:flex-shrink 属性
- 第四课时:flex-basis 属性
- 第五课时:flex 属性
- 第六课时:align-self 属性
- 第四节:Flex 实例
- 第一课时:常见页面布局
- 第三章:响应式布局
- 第一节:概述
- 第二节:媒体查询
- 第一课时:概述
- 第二课时:响应式设计
- 第三节:栅格系统
- 第一课时:概述
- 第二课时:案例分析
- 第三课时:Bootstrap 简介
- 第四节:响应式案例
- 第一课时:三星首页
- 第四章:移动端适配
- 第五章:移动端事件
- 第一节:概述
- 第二节:touch 事件
- 第三节:触摸事件对象
- 第四节:其他事件
- 第五节:移动端幻灯片
- 第六章:移动端常见问题
- 第一节:浏览器兼容性
- 第二节:移动端动画
- 第三节:300ms 延迟
- 第四节:文字溢出省略
- 第五节:水平居中和垂直居中
- 第七章:项目案例
- 第一节:美团外卖
- 第一课时:首页
- 第二课时:订单页面
- 第三课时:我的页面
- 第四课时:详情页面
- 第五课时:购物车页