因为技术栈的问题,我们选用antd-mobile写了一个H5(不做react-native);目前遇到一些坑,在这里做个记录:希望大家能够多多补充!
问题1
在配置高清模式下,iphone5 和iphone6分辨率上没有问题,但是在6P适配就不行了!
解决:
在<script></script>标签里面加入antd-mobild的高清代码后添加
if (isIos && dpr == 3 ) { // 如果为 iOS, 按 2x 处理,dpr 设为 2; dpr = 2; }
完整代码如下:
(function (baseFontSize, fontscale) {
var _baseFontSize = baseFontSize || 100;
var _fontscale = fontscale || 1;
var win = window;
var doc = win.document;
var ua = navigator.userAgent;
var matches = ua.match(/Android[\S\s]+AppleWebkit\/(\d{3})/i);
var UCversion = ua.match(/U3\/((\d+|\.){5,})/i);
var isUCHd = UCversion && parseInt(UCversion[1].split('.').join(''), 10) >= 80;
var isIos = navigator.appVersion.match(/(iphone|ipad|ipod)/gi);
var dpr = win.devicePixelRatio || 1;
if (!isIos && !(matches && matches[1] > 534) && !isUCHd) {
// 如果非iOS, 非Android4.3以上, 非UC内核, 就不执行高清, dpr设为1;
dpr = 1;
}
if (isIos && dpr == 3 ) {
// 如果为 iOS, 按 2x 处理,dpr 设为 2;
dpr = 2;
}
var scale = 1 / dpr;
var metaEl = doc.querySelector('meta[name="viewport"]');
if (!metaEl) {
metaEl = doc.createElement('meta');
metaEl.setAttribute('name', 'viewport');
doc.head.appendChild(metaEl);
}
metaEl.setAttribute('content', 'width=device-width,user-scalable=no,initial-scale=' + scale + ',maximum-scale=' + scale + ',minimum-scale=' + scale);
doc.documentElement.style.fontSize = _baseFontSize / 2 * dpr * _fontscale + 'px';
window.viewportScale = dpr;
})();
if(!window.Promise) {
document.writeln('<script src="https://as.alipayobjects.com/g/component/es6-promise/3.2.2/es6-promise.min.js"'+'>'+'<'+'/'+'script>');
}
问题2
SVG的配置问题(!!!暂时还没有解决,说是版本问题)