记一次内嵌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