前提:
介于现在很多活动都使用了 类似全屏滚动效果 尤其在微信里面 我自己开发了一个快速构建 此类项目的控件 与市面上大部分控件不同的是此控件还支持元素的动画效果 并提供多种元素效果 基于 zepto.js
功能清单:
1 快速实现页面全屏滚动效果。并提供多种翻页效果,兼容大部分 ios 和 android 系统。
2 支持在页面中添加多种动画元素效果 来实现淡入,滑入等效果。
3 支持配置音乐功能。
4 支持摇一摇接口功能。
组件核心代码原理:
1 页面滚动
在移动页面上如果想使用滚动,如过没有任何动画效果,那么肯定大家首先想到的就是用滚动条来滚动,但这样的滚动比较单调,实现动画效果比较困难,于是就想出了利用 css3 和 div 的绝对定位来实现。
1 2 3 4 5 6 7 8 9 10 11 |
<body> <div class="item item1"> </div> <div class="item item2"> </div> <div class="item item3"> </div> </body> |
然后给每个 div 设置绝对定位样式
1 2 3 4 5 6 7 8 9 |
.item { position: absolute; top: 0; left: 0; width: 100%; height: 100%; overflow: hidden; background-position: center; } |
这样页面上的每个 div 都相当于一个页面 只不过重叠了而已,接下来就要利用 javascript 和 css 让这些页面可以滚动 (利用 touch 时间改变 div 的 transform 来实现滚动)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 |
function touchStart(event) { if (dragStart !== null) return; if (event.touches) { event = event.touches[0]; } //抓取时的所在位置 dragStart = event.clientY; } function touchMove (event) { if (dragStart === null) return; if (event.touches) { event = event.touches[0]; } //得到抓取开始时于进行中的差值的百分比 percentage = (dragStart - event.clientY) / window.screen.height;//和屏幕高度做比较 if (percentage > 0) { // //向上拖动 var translateY = 1 - 0.4*percentage;//位置系数,可以微调 $(event.target).next().css('-webkit-transform', 'translateY('+translateY*100+'%)'); //下一个item上移动 } else { //向下拖动 var translateY = -(0.4*percentage); $(event.target).css('-webkit-transform', 'translateY('+translateY*100+'%)');//当前item下移动 } } function touchEnd (event) { dragStart = null;//标志位值空 //抓取停止后,根据临界值做相应判断 if (percentage >= dragThreshold) {//向下滚动 $(event.target).css('-webkit-transform', 'translateY(-100%)'); $(event.target).next().css('-webkit-transform', 'translateY(0)'); } else if ( Math.abs(percentage) >= dragThreshold ) {//向上滚动 $(event.target).css('-webkit-transform', 'translateY(100%)'); } else {//没有达到临界值 恢复原样 $(event.target).next().css('-webkit-transform', 'translateY(100%)'); } //重置percentage percentage = 0; } |
这里有几点说明一下:
1) 使用 translate3d 来替换 translateY 可以开启硬件加速 在渲染上会好一些。
2) 在执行下一页或者上一页时 可以给 div 添加 css3 动画来使其滚动带有一定的动画效果,组件提供 8 中翻页效果。
2 元素的淡入淡出:
元素入场的动画效果主要是利用 css3 来实现
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
.fadeIn { animation-name: fadeIn; -webkit-animation-name: fadeIn; animation-duration: 1.5s; -webkit-animation-duration: 1.5s; animation-timing-function: ease-in-out; -webkit-animation-timing-function: ease-in-out; } @keyframes fadeIn { 0% { transform: scale(0); opacity: 0.0; } 60% { transform: scale(1.1); } 80% { transform: scale(0.9); opacity: 1; } 100% { transform: scale(1); opacity: 1; } } @-webkit-keyframes fadeIn { 0% { -webkit-transform: scale(0); opacity: 0.0; } 60% { -webkit-transform: scale(1.1); } 80% { -webkit-transform: scale(0.9); opacity: 1; } 100% { -webkit-transform: scale(1); opacity: 1; } } |
该元素首先是隐藏的,在页面滑入视窗时将其显示,就会应用上 css3 设定的动画效果,延伸出来不仅 fadeIn 效果,许多效果都可以设定, 另外可以给元素添加 data-delay 属性来控制元素的执行顺序。
组件使用方法:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
{ 'type' : 1,//翻页的动画效果 共有8种可以使用 'pageShow' : function(page){}, 'pageHide' : function(page){}, 'useShakeDevice' : {//是否使用手机摇一摇接口 'speed' : 30, 'callback' : function(page){} }, 'useParallax' : true,//是否使用parallax效果可参看demo第六页 'useArrow' : true,//是否使用箭头 'useAnimation' : true,//是否使用元素动画效果 'useMusic' : {//是否使用音乐 'autoPlay' : true, 'loopPlay' : true, 'src' : 'http://mat1.gtimg.com/news/2015/love/FadeAway.mp3' } }; |
几种效果的预览:
相关文档和说明:
更详细的文档可以查看:http://lvming6816077.github.io/H5FullscreenPage/
后续会对这个组件增加一些新的功能 例如增加 canvas 涂抹元素和可拖拽元素等等,如果大家有好的建议也可以留言。
blackdaniel 2017 年 9 月 4 日
在手机上 slideLeft 和 slideRight 失效了,不知道怎么办,谢谢
赵明燕 2016 年 12 月 2 日
在没有浏览器缓存时,通过捕捉页面加载画面,可以看到所有的 iterm,即从第一页到最后一页会快速的过一遍,再从最后一页,回到第一页,这个问题要怎样解决 ?
贺赫赫 2016 年 8 月 2 日
demo 的音乐怎么换?
赵明燕 2016 年 12 月 2 日
H5FullscreenPage.init( { ‘type’:2, ‘pageShow’ : function(dom){ }, ‘pageHide’ : function(dom){ }, ‘useMusic’ : {//是否使用音乐 ‘autoPlay’ : false, ‘loopPlay’ : false, ‘src’ : ” } }); 在最后一项 useMusic 那里的 src 写上音乐的路径
智取小师妹 2016 年 7 月 6 日
用这个组件没找到向上滑动和向下滑动时的回调,然后自己扩展了下 (主要是想 向上 或者 向下 滑动的时候想改变当前场景的背景色):找到 percentage = (dragStart – event.clientY) / window.screen.height;// if (percentage > 0) { // //向上拖动添加:opt.up.call(this,arguments); 找到 } else if (item.prev()) {添加:opt.down.call(this,arguments);//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////前台调用增加新参数:’up’:function(Touch){ //向上滑动时触发 }, ‘down’:function(Touch){ //向下滑动时触发 } 还有一件事是求楼主能够拉我进 AlloyTeam 公众群,我申请了快 1 年了,没人搭理我,555555555~~
小月博客 2016 年 1 月 21 日
还真不错,现在很流行这个
Yang 2016 年 1 月 5 日
‘pageShow’ : function(page){} 这个 page 参数怎么用?
姚仔 2015 年 9 月 18 日
但是返回在执行都不行了 ! 求大神们指点啊!
2015年4 | 一世浮华一场空 2015 年 7 月 6 日
[…] 全屏滚动效果 H5FullscreenPage.js […]
2015年4 - 编程技术分享 2015 年 7 月 6 日
[…] 全屏滚动效果 H5FullscreenPage.js […]
2015年4 - java技术分享 2015 年 7 月 6 日
[…] 全屏滚动效果 H5FullscreenPage.js […]
2015年4 - php技术分享 2015 年 7 月 6 日
[…] 全屏滚动效果 H5FullscreenPage.js […]
2015年4-6月-前端开发月刊 – 豪情 | 查问题 2015 年 7 月 6 日
[…] 全屏滚动效果 H5FullscreenPage.js […]
吕鸣 2015 年 7 月 1 日
我用魅族看看
吕鸣 2015 年 7 月 1 日
我看下
陌哥 2015 年 7 月 1 日
小米 note,原生浏览器没问题,微信浏览器只能划第一屏,后面就划不动了
吕鸣 2015 年 7 月 1 日
http://lvming6816077.github.io/H5FullscreenPage/ 是这个页面的二维码扫了不行么 我我之前修复过这个问题
陌哥 2015 年 7 月 2 日
谢谢,从这个网址下载的是没问题的,我之前是从 github 上直接下载的,是有问题的。
slert 2015 年 5 月 13 日
在我的锤子手机上划不动
野菜 2015 年 5 月 13 日
不兼容魅族浏览器,要哭了,赶项目还得好好研究一下 TOT
yanhaijing 2015 年 5 月 13 日
https://github.com/yanhaijing/zepto.fullpage
类似产品
godLike 2015 年 4 月 22 日
收藏了.
tcdona 2015 年 4 月 22 日
感谢分享,参考 zxx 的切屏动画库 http://www.mobilebone.org/
我发现其实这类动画应该抽象成更通用的动画组件,分为 [[in,out],reverse] 的组合状态,即:每个页面是有进入退出和返回状态的。
还需要组件化可以随时按需要装卸
TAT.tennylv 2015 年 4 月 22 日
‘pageShow’ : function(page){}, 当执行完一次翻页操作时,当前页面进入屏幕完成时触发的方法
‘pageHide’ : function(page){}, 当执行完一次翻页操作时,上一个当前页面离开屏幕时触发的方法
可以标识页面的状态