其他分享
首页 > 其他分享> > 记一次内嵌H5页面的样式出错(放大)问题

记一次内嵌H5页面的样式出错(放大)问题

作者:互联网

操作A: webview.getSettings().setTextZoom(100)

安卓有个很坑的点,他会重写内嵌H5页面(rem)的样式。字体有缩放也就算了,关键对图片的样式也会有影响。
如果遇到不太严谨的APP开发,测试环境都由操作A,生产环境没有的。。。那就绝了。。。

联系APP同事,他们说其他渠道对接过来都没问题【微笑脸】。
各种查询之后,在父组件加以下js解决。加在index.js的<script />里了。
具体原因后面再深究。
(function(doc, win) {
    var docEl = doc.documentElement,
        isIOS = navigator.userAgent.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/),
        dpr = isIOS ? Math.min(win.devicePixelRatio, 3) : 1,
        dpr = window.top === window.self ? dpr : 1, //被iframe引用时,禁止缩放
        dpr = 1,
        scale = 1 / dpr,
        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';
    docEl.dataset.dpr = dpr;
    var metaEl = doc.createElement('meta');
    metaEl.name = 'viewport';
    metaEl.content = 'initial-scale=' + scale + ',maximum-scale=' + scale + ', minimum-scale=' + scale;
    docEl.firstElementChild.appendChild(metaEl);
    var recalc = function() {
        var width = docEl.clientWidth;
        if (width / dpr > 750) {
            width = 750 * dpr;
        }
        // 乘以100,px : rem = 100 : 1
        docEl.style.fontSize = 100 * (width / 750) + 'px';
    };
    recalc()
    if (!doc.addEventListener) return;
    win.addEventListener(resizeEvt, recalc, false);
})(document, window);

 

 

标签:内嵌,scale,dpr,metaEl,H5,window,docEl,100,页面
来源: https://www.cnblogs.com/guoqiaoqiao/p/13027018.html