移动 Web 开发问题和优化小结

1.前言

到目前为止,互联网行业里,手机愈来愈智能化,移动端占有的比例愈来愈高,尤为实在电商,新闻,广告,游戏领域。用户要求愈来愈高,网站功能愈来愈好,效果愈来愈炫酷,这就要求咱们产品质量愈来愈高,web前端开发而言是一个挑战,是一个难题,也是一个机遇。如何让咱们所开发的手机页面能有更好的交互体验,就是这篇文章的主旨:移动web开发问题和优化小结。这个只是我本身在开发的时候知道的坑,若是你们有遇到什么别的坑,欢迎补充,或者以为我哪里写错了,欢迎指点!

2.Meta标签

页面在手机上显示时,增长这个meta可让页面强制让文档的宽度与设备的宽度保持1:1,而且文档最大的宽度比例是1.0,且不容许用户经过点击或者缩放等操做对屏幕放大浏览。(这个在ios10以上的版本已经失效了,即便加了下面的meta,用户双击,缩放仍是能够缩放页面。你们能够按照开发需求,参考下面的链接进行限制-- ios10中禁止用户缩放页面

<meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0;" name="viewport" />复制代码
禁止ios上自动识别电话

<meta content="telephone=no" name="format-detection" />复制代码
禁止android上自动识别邮箱

<meta content="email=no" name="format-detection" />复制代码
下面两个是针对ios上的safari上地址栏和顶端样式条的(个人手机是安卓,这个没很仔细测试过,可是都有加上)

<meta name="apple-mobile-web-app-capable" content="yes" />
<!-- 据说在ios7以上版本就没效果了 -->
<meta name="apple-mobile-web-app-status-bar-style" content="black" />
<!-- 可选default、black、black-translucent 可是我都是用black-->复制代码

3.打电话发短信

<a href="tel:020-11811922">打电话给:0755-10086</a>
<a href="sms:10086">发短信给: 10086</a>
复制代码

4.css3过渡动画开启硬件加速

ps:网上有说这个用了,手机的耗电量也会增长。我本身也在手机上粗略试过,确实有那么一回事,日常看博客,5分钟左右少1%,用了硬件加速3分钟左右就少1%,你们注意合理使用。

.translate3d{
       -webkit-transform: translate3d(0, 0, 0);
       -moz-transform: translate3d(0, 0, 0);
       -ms-transform: translate3d(0, 0, 0);
       transform: translate3d(0, 0, 0);
 }复制代码

说到这里,也顺便说下动画或者过渡的两个建议:css

1.在手机上(其实PC也是同样)。CSS3动画或者过渡尽可能使用transform和opacity来实现动画,不要使用left和top。
2.动画和过渡能用css3解决的,就不要使用js。若是是复杂的动画可使用css3+js(或者html5+css3+js)配合开发,效果只有想不到,没有作不到。

5.移动端click屏幕产生200-300 ms的延迟响应

click事件由于要等待确认是不是双击事件,会有300ms的延迟(两次点击事件间隔小于300ms就认为是双击),体验并很差。如今的解决方案,第一个就是采用touchstart或者touchend代替click。或者封装tap事件来代替click 事件,所谓的tap事件由touchstart事件+ touchmove(判断是不是滑动事件)+touchend事件封装组成。
关于touch和鼠标事件的延迟说明,我引用叶小钗大神博客里面的一张图片,以下

clipboard.png

在手机上,click的延迟将近400ms。对于用户而言,是一个很严重的延迟了!因此在手机上,并不建议用click。
附上叶小钗大神的原文-- 手持设备点击响应速度,鼠标事件与touch事件的那些事

6.图片优化

6-1.base64编码图片替换url图片

这个应该没什么好解释的,就是能不发请求的就不要发,对于一些小图标(我这作法是把8K如下的图标都转换成base64)之类的,能够将图片用base64,来减小请求的发送。尤为是在移动端,请求显得特别珍贵,在网速的很差的状况下,请求就是珍贵中的珍贵。

6-2.图片压缩

对于整个网站来讲,图片是最占流量的资源之一,能不使用就不适用,图标但是使用base64编码,字体图标代替,SVG等来代替,使用就要选择最合适的格式,合适的尺寸,而后压缩--这里推荐腾讯推出的 智图
PS:过分压缩图片大小影响图片显示效果,可能会使得图片变得模糊,通常来讲,品质在60左右就差很少了!

6-3.图片懒加载

首屏加载的快慢,直接影响用户的体验,建议将非首屏的图片资源放到用户须要时才加载。这样能够大大优化首屏加载,减小首屏加载所须要的时间!
ps:懒加载要使用js频繁操做dom,期间会致使大量重绘渲染,影响性能。

6-4.img仍是background

图片的展现方式有两种,一种是以图片标签显示,一种是以背景图片显示!下面写了这二者的区别。
img: html中的标签 img是网页结构的一部分会在加载结构的过程当中和其余标签一块儿加载。
background:css背景图存在的图片background会等到结构加载完成(网页的内容所有显示之后)才开始加载
也就是说,网页会先加载标签 img的内容,再加载背景图片 background引用的图片。引入一张图片,那么在这个图片加载完成以前, img后的内容不会显示。而用 background来引入一样的图片,网页结构和内容加载完成以后,才开始加载背景图片,网页内容能正常浏览,可是看不到背景图片。至于这两种,你们按照习惯,需求等权重因素选择!

7.快速回弹滚动

在ios上,若是存在局部滚动,就要加这个属性了!若是不加,滚动会很慢,看起来也会有一卡一卡的感受。

-webkit-overflow-scrolling: touch;复制代码
可是,加上了这个,在ios上会产生bug。

以下布局

clipboard.png

.fb-box是一个大div,包含着页面上的全部元素,包括所看到的那个弹窗.dialog-img,而且设置了height:100%;-webkit-overflow-scrolling:touch;position:relative;html


定位须要, -webkit-overflow-scrolling:touch;也须要,可是这样设置,在 ios上会有一个 bug,页面滚动必定的距离后,点击了显示弹窗,再关闭的话,就会发现,弹窗的一部分还“留在页面上”。

clipboard.png

解决方案1:
把弹窗的 div.fb-box以兄弟节点的方式布局,在外层再弄一个 div包住,这个坑就算爬起来了,效果以下

clipboard.png

clipboard.png

解决方案2:
.fb-box去掉 position:ralative;。让弹窗的 div参考 body定位!

8.谨慎使用fixed

ios下 fixed元素容易定位出错,软键盘弹出时,影响 fixed元素定位,会发生元素错位(滚动一下又恢复),有时候会出现闪屏的效果。我也搜过一下这个问题,发现别人还遇到了我没遇到过的问题!真是,哎~。因此在手机上,不建议用 fixed定位,使用 absolute代替!若是必定要用,写好了以后,必定要多测试几回!

9.消除transition闪屏

PS:这个问题,我近段时间开发,貌似不加上这个代码也没什么影响,可是之前就是要求加,就加上了,如今没加上,也没反馈有什么问题!

.no-flash { 
        -webkit-transform-style: preserve-3d; 
        -webkit-backface-visibility: hidden; 
        -webkit-perspective: 1000; 
} 复制代码

10.ios系统中去掉元素被触摸时产生的半透明灰色遮罩

a,button,input,textarea{-webkit-tap-highlight-color: rgba(0,0,0,0;)}复制代码

11.ios中去掉默认input默认样式

input,button,textarea{-webkit-appearance: none;}复制代码

12.左右滑动,避免页面跟着滑动


这个细节是我在基于vue开发焦点图的时候遇到的,后来本身找不到方法,直接在sf上提问了,你们能够去参考下: 移动端轮播图,上下滑动的时候不触发页面的滚动
ps:滑动我没有使用什么库,是我根据touchstart和touchend的移动距离来判断是左右滑动或者上下滑动!

13.vue-router与微信分享的问题

分享发送的链接是下面这样
http://www.example.com/dist/html#/index?utm_source=share
http://www.example.com/dist/html#/index.html/index?utm_source=share
可是分享以后的实际链接是下面这样的,别人点击的分享出去的连接,就会打不开网页
http://www.example.com/dist/html?from=xxxx#/index&utm_source=share
http://www.example.com/dist/html#/index.html?from=xxxx/index&utm_source=share

解决方案
1.自定义分享URL地址
2.避免使用单文件应用

14.iphoneX的齐刘海

苹果公司新出的手机,出了没多久,段子手就坐不住了,各类调侃,可是今天咱们聊那个!聊下iphoneX给前端带来的困扰,也是给ui带来的困扰吧!下面引入大漠,张鑫旭等人对iphoneX齐刘海的一个解决方案!避免到时候跳坑!
iPhone X的缺口和CSS
借助CSS Shapes实现元素滚动自动环绕iPhone X的刘海
剖析 iOS 11 网页适配问题

手机管家iPhoneX的适配总结
前端

15.其它参考

上面所说都是遇到的具体问题,至于还有一些比较笼统的细节优化,或者开发遇到的问题,好比:压缩代码,图片,合并文件等。你们能够参考下面的资源,这些我不展开说了!

1. web移动前端有哪些优化方案?
2. web移动端页面性能优化方案
3. Web前端优化最佳实践及工具集锦
4. 移动前端系列——移动页面性能优化
5. Web性能优化:图片优化

16.小结

我在移动web(手机网站)上,遇到的问题,暂时就是上面这些了!确定仍是会有不少我没遇到过的问题,这些之后会记录,可是不必定会以文章方式发表。若是你们在开发移动网站的时候,有遇到过什么大大小小的问题,在评论或者本身以文章方式提醒!方便让之后的避免踩坑!最后,若是你们有什么补充或者以为我哪里写得很差,写错了!欢迎指点!


-------------------------华丽的分割线--------------------
想了解更多,关注关注个人微信公众号:守候书阁vue

相关文章
相关标签/搜索