移动web开发技巧收集
meta相关
- 设置viewport - <meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0,user-scalable=no">
- 设置格式检测format-detection - <meta name="format-detection" content="telephone=no,email=no,adress=no">
- 添加到主屏幕后,全屏显示 - <meta name="apple-touch-fullscreen" content="yes"> <meta name="full-screen" content="yes">
- 开启webapp功能,全屏显示,删除默认的工具栏和菜单栏 - <meta name="apple-mobile-web-app-capable" content="yes">
- 设置苹果状态栏显示样式为black - <meta name="apple-mobile-web-app-status-bar-style" content="black">
link相关(web app)
- 设置web应用程序的启动画面(对应不同设置使用不同size的图片) - <link rel="apple-touch-startup-image" size="640x1096" href="/startup5.png" media="(device-height:568px)"> <link rel="apple-touch-startup-image" size="640x920" href="/startup.png" media="(device-height:480px)">
- 添加至主屏幕(桌面)时的图标 - <link rel="apple-touch-icon-precomposed" sizes="57x57" href="/touch-icon-57-precomposed.png"> <link rel="apple-touch-icon-precomposed" sizes="72x72" href="/touch-icon-72-precomposed.png"> 各尺寸自适应代码:默认:57x57; iPad:72x72; iPhone 4和Retina屏:114x114(原尺寸的2倍);
CSS相关
- 字体大小设置 - html, body { font-size: 10px; } otherElement { font-size: 1.4rem; }
- 实现网页在Safari快速滚动和回弹 - body { position: relative; -webkit-overflow-scrolling: touch; }
- 屏蔽ios和android下点击元素时出现的阴影 - body { -webkit-tap-highlight-color: rgba(255,255,255,0); }
- 阻止旋转屏幕时自动调整字体大小 - body { -webkit-text-size-adjust: 100%; }
- 禁止用户选中文字 - body { -webkit-user-select:none; }
- 禁止长按屏幕出现系统菜单(可以:禁止用户保存图片,复制图片,在新窗口打开) - img { -webkit-touch-callout:none; }
- 屏蔽输入框怪异的内阴影 - input,textarea { -webkit-appearance:none }
- 做高清图标(宽高各缩放到一半: 100 100 -> 50 50) - background-size
- 设置元素的宽高 - -webkit-box-sizing: border-box;
DOM相关
- 自动大写与自动修正<input type="text" autocapitalize="off" autocorrect="off" />
图片设置相关
- 通常情况下设计师在设计移动网页psd图片时要按照 320 320 的两倍来设计图片大小,即 640 640。然后从图片到页面的时候统一又缩放到一半,图片用 background-size 来设置或img标签,这样做可以放图片在不同尺寸的设备上显示差异不会太大。
一些实用技巧
- 让元素border包含在的指定的宽高范围内border-size: border-box;
根据不同的设备宽度来改变根元素的字体大小
(function (doc, win) {
    var docEl = doc.documentElement,
        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
        recalc = function () {
            var clientWidth = docEl.clientWidth;
            if (!clientWidth) return;
            docEl.style.fontSize = 100 * (clientWidth / 320) + 'px';
        };
    // Abort if browser does not support addEventListener
    if (!doc.addEventListener) return;
    win.addEventListener(resizeEvt, recalc, false);
    doc.addEventListener('DOMContentLoaded', recalc, false);
})(document, window);
Retina屏幕一像素问题完美解决方案(用这种方法的话,所有的长度单位都必须用rem)
//根据屏幕大小及dpi调整缩放和大小, 由于dpr=3时候,经过缩放处理界面会变得非常模糊,所以dpr>=2时做相同处理
(function() {
    var scale = 1.0;
    var ratio = 1;
    if (window.devicePixelRatio >= 2) {
        scale *= 0.5;
        ratio *= 2;
    }
    var text = '<meta name="viewport" content="initial-scale=' + scale + ', maximum-scale=' + scale +', minimum-scale=' + scale + ', width=device-width, user-scalable=no" />';
    document.write(text);
    document.documentElement.style.fontSize = 50*ratio + "px";
})();
此文章未完,将会不断更新总结