ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2020-06-02 09:54:46  阅读:284  来源: 互联网

标签:内嵌 scale dpr metaEl H5 window docEl 100 页面


操作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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有