美文网首页让前端飞
web移动开发资源整理之常见bug的解决方案

web移动开发资源整理之常见bug的解决方案

作者: 器宇轩昂1988 | 来源:发表于2016-11-03 15:46 被阅读191次

模拟按钮hover效果

移动端触摸按钮的效果,可明示用户有些事情正要发生,是一个比较好体验,但是移动设备中并没有鼠标指针,使用css的hover并不能满足我们的需求,还好国外有个激活css的active效果,代码如下:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport">
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="black" name="apple-mobile-web-app-status-bar-style">
    <meta content="telephone=no" name="format-detection">
    <meta content="email=no" name="format-detection">
    <style type="text/css">
        a {
              -webkit-tap-highlight-color: rgba(0,0,0,0);
        } 
        .btn-blue{
            display:block;
            height:42px;
            line-height:42px;
            text-align:center;
            border-radius:4px;
            font-size:18px;
            color:#FFFFFF;
            background-color: #4185F3;
        } 
        .btn-blue:active{background-color: #357AE8;} 
    </style>
</head>
<body>
    <div class="btn-blue">按钮</div>
    <script type="text/javascript">document.addEventListener("touchstart", function(){}, true)</script>
</body>
</html>

兼容性ios5+、部分android 4+、winphone 8
要做到全兼容的办法,可通过绑定ontouchstart和ontouchend来控制按钮的类名

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport">
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="black" name="apple-mobile-web-app-status-bar-style">
    <meta content="telephone=no" name="format-detection">
    <meta content="email=no" name="format-detection">
    <style type="text/css">
        a {-webkit-tap-highlight-color: rgba(0, 0, 0, 0);}
        .btn-blue {
            display: block;
            height: 42px;
            line-height: 42px;
            text-align: center;
            border-radius:4px;
            font-size: 18px;
            color: #FFFFFF;
            background-color: #4185F3;
        }
        .btn-blue-on {background-color: #357AE8;}
    </style>
</head>
<body>
<div class="btn-blue">按钮</div>
<script type="text/javascript">
    var btnBlue = document.querySelector(".btn-blue");
    btnBlue.ontouchstart = function(){this.className = "btn-blue btn-blue-on"} 
    btnBlue.ontouchend = function(){this.className = "btn-blue"}
</script>
</body>
</html>

屏幕旋转的事件和样式

window.orientation,取值:正负90表示横屏模式、0和180表现为竖屏模式;

window.onorientationchange = function(){
    switch(window.orientation){
        case -90:        
        case 90:            
            alert("横屏:" + window.orientation);            
            break;
        case 0:        
        case 180:             
            alert("竖屏:" + window.orientation);            
            break;    
}}
//竖屏时使用的样式
@media all and (orientation:portrait) {.css{}}
//横屏时使用的样式
@media all and (orientation:landscape) {.css{}}

audio元素和video元素在ios和andriod中无法自动播放

应对方案:触屏即播

$('html').one('touchstart',function(){ audio.play()})

可参考《无法自动播放的audio元素

摇一摇功能

HTML5 deviceMotion:封装了运动传感器数据的事件,可以获取手机运动状态下的运动加速度等数据。

手机拍照和上传图片

<input type="file">的accept 属性

<!-- 选择照片 -->
<input type=file accept="image/*">
<!-- 选择视频 -->
<input type=file accept="video/*">

使用总结:

  • ios 有拍照、录像、选取本地图片功能
  • 部分android只有选取本地图片功能
  • input控件默认外观丑陋

消除transition闪屏

网络都是这么写的,但我并没有测试出来,应该只是兼容低版本的手机

.css{
/*设置内嵌的元素在 3D 空间如何呈现:保留 3D*/
 -webkit-transform-style: preserve-3d;
//设置进行转换的元素的背面在面对用户时是否可见:隐藏
-webkit-backface-visibility: hidden;
}

开启硬件加速

  • 解决页面闪白
  • 保证动画流畅
.css{
 -webkit-transform: translate3d(0, 0, 0);
 -moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
}

设计高性能CSS3动画的几个要素

  • 尽可能地使用合成属性transform和opacity来设计CSS3动画,不使用position的left和top来定位
  • 利用translate3D开启GPU加速

fixed定位的bug

  • ios下fixed元素容易定位出错,软键盘弹出时,影响fixed元素定位
  • android下fixed表现要比iOS更好,软键盘弹出时,不会影响fixed元素定位
  • ios4下不支持position:fixed

播放视频不全屏

<video x-webkit-airplay="true" webkit-playsinline="true" preload="auto" autoplay src="http://"></video>

相关文章

  • web移动开发资源整理之常见bug的解决方案

    模拟按钮hover效果 移动端触摸按钮的效果,可明示用户有些事情正要发生,是一个比较好体验,但是移动设备中并没有鼠...

  • web移动开发资源整理之常见问题

    移动端如何定义字体font-family 中文字体使用系统默认即可,英文用Helvetica 移动端字体单位fon...

  • 移动端常见bug汇总001

    前言 本文是摘录整理了移动端常见的一些bug以及解决方案,第一篇,后面还会有持续的文章更新整理。 点击样式闪动 Q...

  • 移动web端常见bug

    本文是摘录整理了移动端常见的一些bug以及解决方案 点击样式闪动 Q: 当你点击一个链接或者通过Javascrip...

  • web移动开发资源整理之meta基础

    本系列文章大都来自于网上大神的解决方案,在这里罗列出来,只为开发时方便查询,创作权归原作者所有。简单做下总结,首先...

  • WEB开发资源整理

    1,bootstrap :http://www.bootcss.com/ 2,JQuery轮播组件:http://...

  • 移动端常见bug

    移动端常见bug整理原文链接 点击样式闪动 Q: 当你点击一个链接或者通过Javascript定义的可点击元素的时...

  • 移动端常见bug汇总002

    前言 上一篇之后我从各个小伙伴那里收集到了第二波移动端常见的bug以及其解决方案,部分解决方案可能不准确或者存在问...

  • WEB测试常见BUG

    1、翻页 翻页时,没有加载数据为空,第二页数据没有请求 翻页时,重复请求第一页的数据 翻页时,没有图片的内容有时候...

  • 新能力 | 云开发基于Flutter的云端一体化探索

    导语 Flutter 框架是当下移动客户端开发最热门的解决方案,除了可以跨 Android、iOS、web 三端之...

网友评论

    本文标题:web移动开发资源整理之常见bug的解决方案

    本文链接:https://www.haomeiwen.com/subject/zbabuttx.html