如何玩转HTML5移动页面?

   作为一名前端,在拿到设计稿时你有两种选择:

  1.快速输出静态页面

  2.加上高级大气上档次狂拽炫酷屌炸天的动画让页面动起来

  作为一个有志向的前端,当然是选2啦!可是需求时间又很短很短,怎么办呢?

  这次就来谈谈一些动画设计的小技巧,能在你时间不多又没有动画想法的时候瞬间让页面增色不少。

  同时也会谈及移动端H5页面的优化细节与关键点,因此本文章将分为动效篇和优化篇。

  ====前方高能====

  一、CSS3时序错开渐显动画

  这是一种比较常用的动画,它的优点是节奏感强,做法就是先让每个元素隐藏,然后当页面呈现后每个元素错开时间出现。

  例子(忽略兼容前缀和无关属性):


  效果就是两个元素分别从上面掉下来,这里有个小细节(keyframes),为了让掉下来的动画生动点,应该是在90%的时候先掉下一点点,然后瞬间在100%时回跳5px。

  还有个细节,安卓2.3.*不能良好支持-webkit-animation-fill-mode,也就是渐变动画不能停止在最后一帧。有这样一个解决方案:

  1.用Modernizr去检测是否支持这个属性,加上识别类.no-animation-fill-mode;

  2.根据识别类采取以下措施:

  (1)用js模拟同样效果;

  (2)用css屏蔽掉动画;

  (3)或者直接全部都用transition来做(不要keyframes)。

  示例页面如下:


  (注:此案例链接已失效)

  二、CSS3细节强调动画

  一些局部细节如果还是渐现显示,会枯燥没什么感觉,例如标题、按钮等,需要一种强调。

  分两种情况:

  1.如果时间允许的话,基本做法是先把一个元素切成不同的块状,例如小人的手脚都切成不同图片,然后让它们重新组合,再通过赋予不同的CSS动画来让它生动起来,这里引用个webank的例子:


  (点击查看DEMO)

  2.如果时间紧凑,又不像桑尼一样擅长于动画细节,可以使用一些辅助工具:

  Animate.css,通过直接预览选择想要的动效,然后下载它的CSS把对应的keyframe扒下来就好了(引用整个CSS是资源浪费)。

  三、SVG动画

  SVG技术越来越不陌生,使用门槛也渐渐降低,而且SVG动画还可以使用CSS控制。

  先看个生日页面,是个SVG的蛋糕:


  (注:此案例链接已失效)

  可见SVG是很强大的!弥补了CSS3的不足。

  然而这种动画也是略耗时,但有一种比较常用的,就是线条的描绘动画,CSS3比较难实现,这里可以用SVG,看图:


  介绍一个PS插件svgArtisan(目前还未有主页),这个工具可以直接根据PSD的路径图层生成SVG图形。

  接下来就简单了,将设计稿上的路径图形用插件生成对应的SVG,例如是这样的:

  (注意,其中的foreignObject标签内是不支持svg的浏览器会看到一张.m3-svg-nosupport标签下的图片。)


  再使用CSS3的animation控制stroke-dashoffset:


  效果不难吧!SVG还有各种用途,例如制作ICONFONT等,可以深入挖掘。

  四、 重力陀螺仪

  想让页面更有层次感,不妨让设计提供一些碎片元素,例如彩花,星星之类,然后把它们单独切出来放画面前景,使用陀螺仪伴随着手机运动碎片也跟着运动,多么好玩!

  这里提供一个工具可以轻松实现陀螺仪重力效果的:parallax.js

  用法简单,定义一个parallax-obj的父类,把需要动的元素加上layer的类,然后设置动的范围data-depth:


  五、背景音乐&音效

  H5页面要炫酷,画面生动还是不够的,一定要配合生动的音乐。因此可以主动跟设计或产品沟通,让他们可以提供音乐资源,分分钟导致UV猛涨有木有!

  当然,有了音乐,前端也不是直接引用的,还是有点要求:

  1.音乐不宜过长,30s为佳,而且音乐要加上渐现渐隐效果,方便循环播放;

  2.音乐体积要小,音质和流量,在手机上还是优先考虑流量吧。

  一般背景音乐体积可以接受的范围是200K以下,若太大,可以使用格式工厂等软件,降低它的比特率和声道来改变体积。

  接着,只需要简单引用:


  这里有个问题,IOS是不能自动播放音乐的,一定要触发一个用户交互事件,例如点击。

  但是有一种hack的方法可以让IOS微信侧页面自动播放(SAFARI依旧无效):

  通过new一张图片,监听一张图片的onload事件,结束后回调执行音频播放audio.play()即可,原理估计是动了dom结构,相当于执行了一次交互。(有人也用过createEvent模拟,原理也是动了dom。)

  因此,记得暴露一个音乐关闭/打开的按钮,不然肯定被用户骂死。

  六、有趣的loading

  Loading页还是要有的,万一用户网速慢呢?

  以上做了那么多事,如果没有资源加载都是玩不来的,因此还需要一个loading的支持。一般情况下页面体积大于3m则要加上loading页。

  然而loading还是可以做得很有趣的,一般的做法是:

  1.引入品牌,例如APP宣传页;

  2.引入有趣动画,放一个贱贱的人物跳舞给你看;

  3.一切从简,用CSS3简单动画。

  ====最后总结====

  最后,给一个例子结尾吧。

  这是空间5.0预约页第二版,使用了以上的若干方法论,例如loading动画,CSS3动画,SVG星空连线,首屏星球重力感应,音乐(这里使用开启按钮后播放)等等。

  (由于活动已结束,很多运营处都被删掉从简了,忽略那些细节)


  (点击查看DEMO)

  当然,真正要做到高效制作动态H5页面,还是靠积累,因此平时做好的细节动画自己都积累起来,下次分分钟就能用得上。

时间: 2024-10-06 19:10:02

如何玩转HTML5移动页面?的相关文章

玩转HTML5移动页面(动效篇)

  (1) CSS3时序错开渐显动画 这是一种比较常用的动画,它的优点是节奏感强,做法就是先让每个元素隐藏,然后当页面呈现后每个元素错开时间出现. 例子(忽略兼容前缀和无关属性): 效果就是两个元素分别从上面掉下来,这里有个小细节(keyframes),为了让掉下来的动画生动点,应该是在90%的时候先掉下一点点,然后瞬间在100%时回跳5px. 还有个细节,安卓2.3.*不能良好支持-webkit-animation-fill-mode,也就是渐变动画不能停止在最后一帧.有这样一个解决方案: 1

玩转HTML5移动页面(优化篇)

  (1) 动画雪碧图 涉及的动画十分多,用的元素也十分多,请务必使用雪碧图(Sprite)! 网上的工具有一些可以帮助你生成雪碧图的工具,例如CssGaga,GoPng等等,自动化构建工具Grunt和Gulp也提供了相应插件. 特别地,如果单张雪碧图面积实在太大,可以拆分雪碧图,例如拆分成2-4张,因为现代浏览器都支持4-6个同源请求下载,若资源实在太多,也可以考虑把静态资源放在不同源域名下去请求,这里牺牲多几个请求换来图片同时加载比一张图片慢慢加载要好,当然,这需要具体情况去衡量. 顺便提一

六大奇招带你玩转HTML5移动页面动效

  四月份最有技术含量的干货!今天腾讯前端TQ同学来来谈谈一些动画设计的小技巧,能帮你在短时间没动画灵感时瞬间让页面增色,同时也会谈及移动端H5页面的优化细节与关键点 >>> 作为一名前端,在拿到设计稿时你有两种选择: 1.快速输出静态页面 2.加上高级大气上档次狂拽炫酷屌炸天的动画让页面动起来 作为一个有志向的前端,当然是选2啦!可是需求时间又很短很短,怎么办呢? 这次就来谈谈一些动画设计的小技巧,能在你时间不多又没有动画想法的时候瞬间让页面增色不少. 同时也会谈及移动端H5页面的优化

html5各种页面切换效果和模态对话框用法总结

 本文详细总结了html5各种页面切换效果和模态对话框用法.分享给大家供大家参考.具体分析如下: 页面动画: data-transition 属性可以定义页面切换是的动画效果. 例如:<a href="index.html" data-transition="pop">I'll pop</a> data-transition 参数表: 参数说明 slide 从右侧向左滑入页面 slideup 从底部向上滑入 slidedown 从上向下滑入

安卓手机软键盘-HTML5 手机页面 输入表单被键盘遮挡住了

问题描述 HTML5 手机页面 输入表单被键盘遮挡住了 HTML5 手机页面 输入表单被键盘遮挡住了 请问 大神 怎么 js 或者 JQ 判断安卓手机软键盘的键盘隐藏键按下去了? 有使用 uexWindow 方法 能判断到确定键 是 13 但是不知道这个键的键值 是什么? 或者有什么其他方法? 判断窗口尺寸改变的 size 方法无效 解决方案 没有相关的事件来获取隐藏按钮点击,keydown/keyup事件中获取到的keyCode都是0,楚了你说的前往keyCode 13. 可以用计时器监视wi

玩转html5&amp;lt;canvas&amp;gt;画图

玩转html5<canvas>画图 导航 前言 基本知识 绘制矩形 清除矩形区域 圆弧 路径 绘制线段 绘制贝塞尔曲线 线性渐变 径向渐变(发散) 图形变形(平移.旋转.缩放) 矩阵变换(图形变形的机制) 图形组合 给图形绘制阴影 绘制图像(图片平铺.裁剪.像素处理[不只图像.包括其他绘制图形]) 绘制文字 保存和恢复状态(context) 保存文件 结合setInterval制作动画 结语.demo下载   前言      <canvas></canvas>是html

html5-要用wijmo开发Html5前台页面,其有多窗口功能吗

问题描述 要用wijmo开发Html5前台页面,其有多窗口功能吗 需要使用wijmo控件实现如下功能:例如点击student Menu弹出一个student对话框可对学生进行增删改查,点击对话框中的Add按钮,弹出新增学生对话框输入新增信息,点击该对话框Save保存后信息记录在原有student对话框中出现即多个窗口同时操作,求指教

请问各位有没有基于Html5前台页面框架

问题描述 请问各位有没有基于Html5前台页面框架 想利用最新的Html5技术开发页面,请问各位有没有基于Html5前台页面框架以及相关的使用Demo.谢谢! 解决方案 jquery.mobile 可以参考codiqa.com,有设计器 解决方案二: jquery.mobile或者ext的touchhttp://jquerymobile.com/https://www.sencha.com/products/touch/ 解决方案三: 可以使用angularjs,完美支持html5. 解决方案四

HTML5 移动页面自适应手机屏幕宽度详解_相关技巧

网上关于这方面的文章有很多,重复的东西本文不再赘述,仅提供思路,并解释一些其他文章讲述模糊的地方.  1.使用meta标签,这也是普遍使用的方法,理论上讲使用这个标签是可以适应所有尺寸的屏幕的,但是各设备对该标签的解释方式及支持程度不同造成了不能兼容所有浏览器或系统. 首先解释该标签的含义: <meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, ma