(1) 动画雪碧图

涉及的动画十分多,用的元素也十分多,请务必使用雪碧图(Sprite)!

网上的工具有一些可以帮助你生成雪碧图的工具,例如CssGaga,GoPng等等,自动化构建工具Grunt和Gulp也提供了相应插件。

特别地,如果单张雪碧图面积实在太大,可以拆分雪碧图,例如拆分成2-4张,因为现代浏览器都支持4-6个同源请求下载,若资源实在太多,也可以考虑把静态资源放在不同源域名下去请求,这里牺牲多几个请求换来图片同时加载比一张图片慢慢加载要好,当然,这需要具体情况去衡量。

顺便提一下,我写动画的一个小技巧是把每一页的动画分在一个import.css里面,然后最后在主样式中import进去,这样方便调试动画,也容易维护,例如:

//style.css

@import url("reset.import.css");

@import url("loading.import.css");

@import url("m-animate-1.import.css");

@import url("m-animate-2.import.css");

@import url("m-animate-3.import.css");

当然,import不是原生支持的,这里需要一些流程化工具让import的页面在输出之前经过组装-压缩的步骤。

(2)  图片压缩

图片压缩是老生常谈,但是仍然有不少人忘记压缩,那可是活生生的带宽和流量的浪费啊…

压缩图片需要有好工具,有智图,TinyPNG,JPEGmini等等。

依靠工具外,还有以下方式可以优化图片:

1.尽量避免用PNG24。如果图片色彩要求不高,请使用PNG8;

2.使用新格式,WEBP和BPG等新格式的到来,在不用考虑兼容的情况下请大胆尝试;

3.用SVG和ICONFONT代替简单的图标;

4.用FUFU的字蛛来代替艺术字体切图。

(3)多终端兼容

多终端兼容是一切的根基,要知道有人拿着肾6+,有人拿着肾4,大则414×736,小则320×416(IPHONE4在SAFARI保留上下端导航),因此多终端兼容是十分必要的。

曾经有一种派系为320派系,就是大部分页面都是320宽度,因此干脆直接用320的容器来包一切页面,那样也简单,然而IPHOEN6和IPHONE6+的出现简直是灭了这个派系。

那么到底要如何兼容呢?

这里我分了三个时期来说说:

A.设计初期。先审视设计稿,因为320派系的原因,大部分设计稿只考虑到IPHONE5来设计,因此很多背景元素是只有320px宽度(页面实际渲染宽度),例如下图。

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

那么,这时候就需要设计提供一个较长的延伸背景了,最好是可以重复的,用background-repeat可以减少图片大小。

B.设计中期。也就是具体的兼容方法,可以使用CSS3 Media Query和类覆盖。

1.CSS3 Media Query,按范围兼容机型。

@media only screen

and (min-device-width : 375px)

and (max-device-width : 667px)

and (orientation : portrait)

and (-webkit-min-device-pixel-ratio : 2)

{

.page6 .ele-building{top: 69px;}

.page6 .ele-runner{top: 100px;}

.page6 .ele-pophome{top: 16px;}

}

2.类覆盖,这种方式适合直接为小屏或大屏做整体兼容。

首先,为小屏(大屏)加一个识别类,这里小于420表示为小屏幕(IPHONE4有上下导航栏):

var bh = $(window).height();

// 480 - 64 = 416 iphone4

if(bh<420){

$('body').addClass('low-screen');

}

然后,对应识别类加上要变动的元素覆盖,例如:

.page6 .ele-bg{top: 10px;}

.low-screen .page6 .ele-bg{top: 0px;}

C.设计后期。这是最后一步,整体检查和体验,这里面会暴露一些问题,例如元素在IPHONE6P显得小了或者元素在IPHONE4挤不下了,可以来最后大招解决:

1.大屏适当用zoom:(倍率)或者transform:scale(倍率)来增大元素,实测失真根本看不出来,设计师也满意(毕竟不用多做一张图!);

2.小屏适当去掉一些元素,例如一些翻页提示,一些多余图标,可以让优雅降级,把它们 display:none掉。

有以上几步,基本就能兼容大部分机器了。兼容一直是个苦活,但是这是前端必修课,多练就会发觉其实也没有那么难嘛。

(4)交互提示

前面说了,加了音效就要加上音乐切换开关的按钮,不然会被用户骂死。还有其他,例如如果你的页面不能兼容横屏,请监听横屏状态,然后加上适当的横屏提示。

例如:

// 横屏监听

var updateOrientation = function(){

if(window.orientation=='-90' || window.orientation=='90'){

$('.landscape-wrap').removeClass('hide');

console.log('为了更好的体验,请将手机/平板竖过来!');

}else{

$('.landscape-wrap').addClass('hide');

console.log('竖屏状态');

}

};

window.onorientationchange = updateOrientation;

提示越多,界面越友好,有时候设计师会漏掉一些可能出现的页面情况。

作为有态度的前端,请好好把关,让用户有好的体验。

(5)分享接口

H5做好了,要传播分享才能展示你的牛逼轰轰。

然而分享其实是个坑,分享到微信、手Q等都有各种问题。

A.微信

旧微信会使用WeixinJSBridge来声明分享的缩略图、标题、正文等,比较方便。例如:

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

而最新的微信提供了新的微信SDK,需要在公众账号绑定所属域名之后调用SDK作分享,可以说分享功能会更加强大,坑也会更加少。

B.手Q

手Q支持声明meta标签的的分享方式,例如:

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

而若在qq.com域名下也支持api的定义方式。

C.一般化分享

在默认兼容旧版微信、手Q或者各种浏览器,平台,可以用这样的方法:

写h1做标题,p做内容,img做缩略图,只需要把h1隐藏掉就好,这里的缩略图最好要大于200x200px。

例如:

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

当然,这样也有利于搜索引擎拉取信息。

分享的坑还有更多,例如不同浏览器例如QQ浏览器、Chrome也会有自己的默认拉取方式(部分截图作缩略图),需要多加测试优化。

(5)SEO搜索引擎优化

SEO(搜索引擎优化)的基本做法是把页面结构写好,这包括:

1.定义精确的网页标题。你的标题应该有概括性,能明确告知搜索引擎和用户你的网站大概内容和目的,可以是当前页面标题-所属类型-产品名,例如“全民来猜歌-年费黄钻-QQ空间”。

2.针对页面内容补充description和keywords的meta标签。你需要简短总结页面的主要目标,然后补充description,以及根据关键词补充keywords。

3.优化你的超链接和图片。包括优化超链接显示的文本,要具有语义性也要跟超链接的网页具有相关性,例如“空间主页”就不要链接到“www.qq.com”。同时,要补充”title”和”alt”属性,例如“<img
src=’images/apple.jpg’ title=’苹果示例图’ alt=’苹果示例图’
/>”。

4.建立良好的网站导航和sitemap。网站需要有一个良好的导航,控制根目录和各子目录的关键,通过sitemap可以帮助网站主了解网站结构,也方便搜索引擎收录整个站点。

5.优化目录结构和URL。你的URL应该有语义性,简短易懂,例如http://www.apple.com/macbook-air/,而且每一层级都要有它对应的页面展示以及语义。

6.善用h1-h6的标题结构树。合理的标题可以强调文字,也能让搜索引擎更加了解到各标题的重要性,因此建立良好的标题树十分有意义。

7.不断致力于提供优质的内容。社交化分享是网站曝光最快的因素,因此不断提供了优质原创内容才能真正提高你的网站曝光权重。

(6)无障碍

无障碍的普及是一件好事,这让互联网真正地为所有人可用。因此我们也应该为之而努力,无障碍的根基是你页面强壮的语义性和结构性,具体可以参考《腾讯网无障碍说明》了解无障碍的优化手段。

交流群:103791667

转载于:https://www.cnblogs.com/luludehuhuan/p/6180356.html

玩转HTML5移动页面相关推荐

  1. 玩转HTML5移动页面(转自http://tqtan.com/)

    标题起得有点大(๑´ㅂ`๑),今天来谈谈H5移动页面的开发心得(技巧). 一般情况下,拿到设计稿你有两种选择: //条件表达式 产物=设计稿处理?静态输出:让页面动起来: 作为一个有志向的前端,当然不 ...

  2. 单页活动页面html,优秀HTML5活动页面

    一个好的手机活动宣传 更能让人分享 传播是爆炸性的 下面是我平时看到一些好的微信活动宣传页面  分享给大家 其中用到的技术 常做微信活动 专题页面的人 可以看看大神们是怎么做的  这样到自己做的时候 ...

  3. HTML5手机页面里面如何把长按复制避免

    在写HTML5手机页面的时候,有时候会写到一些标签是需要用户长按然后放开的 但是微信里面长按就会出现复制,大大影响了用户体验,那么如何可以避免呢? 我也是最近写到这样的页面,总结了一部分,大家可以作为 ...

  4. html对话框跳转页面,html5各种页面切换效果和模态对话框用法总结

    这篇文章主要为大家介绍了html5各种页面切换效果和模态对话框用法总结,较为详细的介绍了HTML5的各种页面元素的使用技巧,非常具有实用价值,需要的朋友可以参考下 本文详细总结了html5各种页面切换 ...

  5. html5页面的手势,HTML5单页面手势滑屏切换如何实现

    这次给大家带来HTML5单页面手势滑屏切换如何实现,怎么实现HTML5单页面手势滑屏切换?HTML5单页面手势滑屏切换的注意事项有哪些,下面就是实战案例,一起来看一下. H5单页面手势滑屏切换是采用H ...

  6. html5页面适配方法,H5案例分享:HTML5移动页面适配方法

    HTML5移动页面适配方法 之前做过PC页面时考虑最多的是兼容,这是因为浏览器之间的差异引起的.而移动端是基本没有"兼容"的问题了,全是CSS3,是不是很开心,但是开心早了,因为适 ...

  7. 从零玩转HTML5+CSS3项目实战-跟着李南江学编程

    从零玩转HTML5+CSS3项目实战-跟着李南江学编程 1.CSS高级应用 1.边框圆角的基本使用 1.1什么是边框圆角:将直角的边框变为圆角的边框 1.2边框圆角的格式:border-radius: ...

  8. html5页面图片切换,HTML5单页面手势滑屏切换原理

    H5单页面手势滑屏切换是采用HTML5 触摸事件(Touch) 和 CSS3动画(Transform,Transition)来实现的,效果图如下所示,本文简单说一下其实现原理和主要思路. 1.实现原理 ...

  9. html5怎么制作app页面,玩转HTML5移动APP页面(动效篇)

    作为一名前端,在拿到设计稿时你有两种选择: 加上高级大气上档次狂拽炫酷屌炸天的动画让页面动起来 作为一个有志向的前端,当然是选2啦!可是需求时间又很短很短,怎么办呢? 这次就来谈谈一些动画设计的小技巧 ...

最新文章

  1. C 语言——字符串和格式化输入/输出
  2. 深度学习核心技术精讲100篇(七十四)-教你如何最快入门用户画像
  3. 手机邮箱配置QQ邮箱
  4. 论面向对象方法与软件复用关系-z
  5. pycharm快敏捷键
  6. 《梦断代码》阅读笔记之第8章至最后
  7. 10.30完美笔试题
  8. 通用数据链接(UDL)的用法
  9. mysql limit报错_mysql limit 附近老是报错,求帮助!
  10. 多线程之使用读写锁ReentrantReadWriteLock实现缓存系统
  11. Linux socks5转http
  12. POJO类与javaBean类的区别
  13. 基于VHDL的交通灯设计(实训要求)
  14. 城市历年人均GDP API数据接口
  15. 12306GT多线程、分流免费抢票工具使用心德
  16. DHCP 客户端移动位置后无法获取IP地址的解决办法和原因分析
  17. Python正则表达式匹配字符串中的数字
  18. 高德地图实现画线搜索
  19. CISSP考试指南笔记:1.1安全目标
  20. 康耐视In-Sight操作流程

热门文章

  1. python画图程序-无所不能的python编程是怎么快速画图的呢?5分钟学会!
  2. 零基础是学java还是python-零基础更适合学习Java还是python?
  3. python找工作难吗-Python虽然很火,为啥找工作这么难?
  4. python画柱形图-Python绘制柱状图
  5. 爬虫python代码-Python爬虫入门(01) -- 10行代码实现一个爬虫
  6. php和python区别-PHP与Python语言有哪些区别之处?选择哪一个好?
  7. python自学时间-Python 从入门到精通:一个月就够了!
  8. python在会计工作中的应用-python有什么用(会计专业)
  9. python基本语法语句-python基本语法
  10. python网课一般多少钱-Python培训网课一般学费多少?毕业生能承担吗?