zoukankan      html  css  js  c++  java
  • 手机html根据手机分辨率网页文字大小自适应

    问题:不同手机型号屏幕尺寸大不相同,导致同样的文字,有的显示一行,有的显示多行。

    通过查资料和自己的尝试解决;网页开发习惯的px单位,手机html开发不适用。

    源代码如下:

    <!DOCTYPE html>
    <html lang="en">
    <head>
    	<meta charset="UTF-8">
    	<!--防止手机页面缩放-->
        <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">
    
    	<title>Document</title>
    </head>
    <body>
    	<!-- 文字单位设置为rem即可,通过微信开发者工具切换手机型号查看效果。 -->
    	<div style='border:1px red solid;border-radius:100px;font-size:1rem;'>测试手机端文字的自适应</div>
    </body>
    <script>
    
    /*    利用js计算当前设备的DPR,动态设置在html标签上,并动态设置html的font-size,*/
        !function(win, lib) {
            var timer,
                doc     = win.document,
                docElem = doc.documentElement,
    
                vpMeta   = doc.querySelector('meta[name="viewport"]'),
                flexMeta = doc.querySelector('meta[name="flexible"]'),
    
                dpr   = 0,
                scale = 0,
    
                flexible = lib.flexible || (lib.flexible = {});
    
            // 设置了 viewport meta
            if (vpMeta) {
    
                console.warn("将根据已有的meta标签来设置缩放比例");
                var initial = vpMeta.getAttribute("content").match(/initial-scale=([d.]+)/);
    
                if (initial) {
                    scale = parseFloat(initial[1]); // 已设置的 initialScale
                    dpr = parseInt(1 / scale);      // 设备像素比 devicePixelRatio
                }
    
            }
            // 设置了 flexible Meta
            else if (flexMeta) {
                var flexMetaContent = flexMeta.getAttribute("content");
                if (flexMetaContent) {
    
                    var initial = flexMetaContent.match(/initial-dpr=([d.]+)/),
                        maximum = flexMetaContent.match(/maximum-dpr=([d.]+)/);
    
                    if (initial) {
                        dpr = parseFloat(initial[1]);
                        scale = parseFloat((1 / dpr).toFixed(2));
                    }
    
                    if (maximum) {
                        dpr = parseFloat(maximum[1]);
                        scale = parseFloat((1 / dpr).toFixed(2));
                    }
                }
            }
    
            // viewport 或 flexible
            // meta 均未设置
            if (!dpr && !scale) {
                // QST
                // 这里的 第一句有什么用 ?
                // 和 Android 有毛关系 ?
                var u = (win.navigator.appVersion.match(/android/gi), win.navigator.appVersion.match(/iphone/gi)),
                    _dpr = win.devicePixelRatio;
    
                // 所以这里似乎是将所有 Android 设备都设置为 1 了
                dpr = u ? ( (_dpr >= 3 && (!dpr || dpr >= 3))
                        ? 3
                        : (_dpr >= 2 && (!dpr || dpr >= 2))
                            ? 2
                            : 1
                    )
                    : 1;
    
                scale = 1 / dpr;
            }
    
            docElem.setAttribute("data-dpr", dpr);
    
            // 插入 viewport meta
            if (!vpMeta) {
                vpMeta = doc.createElement("meta");
    
                vpMeta.setAttribute("name", "viewport");
                vpMeta.setAttribute("content",
                    "initial-scale=" + scale + ", maximum-scale=" + scale + ", minimum-scale=" + scale + ", user-scalable=no");
    
                if (docElem.firstElementChild) {
                    docElem.firstElementChild.appendChild(vpMeta)
                } else {
                    var div = doc.createElement("div");
                    div.appendChild(vpMeta);
                    doc.write(div.innerHTML);
                }
            }
    
            function setFontSize() {
                var winWidth = docElem.getBoundingClientRect().width;
    
                if (winWidth / dpr > 540) {
                    (winWidth = 540 * dpr);
                }
    
                // 根节点 fontSize 根据宽度决定
                var baseSize = winWidth / 10;
    
                docElem.style.fontSize = baseSize + "px";
                flexible.rem = win.rem = baseSize;
            }
    
            // 调整窗口时重置
            win.addEventListener("resize", function() {
                clearTimeout(timer);
                timer = setTimeout(setFontSize, 300);
            }, false);
    
    
            // 这一段是我自己加的
            // orientationchange 时也需要重算下吧
            win.addEventListener("orientationchange", function() {
                clearTimeout(timer);
                timer = setTimeout(setFontSize, 300);
            }, false);
    
    
            // pageshow
            // keyword: 倒退 缓存相关
            win.addEventListener("pageshow", function(e) {
                if (e.persisted) {
                    clearTimeout(timer);
                    timer = setTimeout(setFontSize, 300);
                }
            }, false);
    
            // 设置基准字体
            if ("complete" === doc.readyState) {
                doc.body.style.fontSize = 12 * dpr + "px";
            } else {
                doc.addEventListener("DOMContentLoaded", function() {
                    doc.body.style.fontSize = 12 * dpr + "px";
                }, false);
            }
    
            setFontSize();
    
            flexible.dpr = win.dpr = dpr;
    
            flexible.refreshRem = setFontSize;
    
            flexible.rem2px = function(d) {
                var c = parseFloat(d) * this.rem;
                if ("string" == typeof d && d.match(/rem$/)) {
                    c += "px";
                }
                return c;
            };
    
            flexible.px2rem = function(d) {
                var c = parseFloat(d) / this.rem;
    
                if ("string" == typeof d && d.match(/px$/)) {
                    c += "rem";
                }
                return c;
            }
        }(window, window.lib || (window.lib = {}));
    
    </script>
    </html>

  • 相关阅读:
    信息学奥赛一本通(C++)在线评测系统——基础(一)C++语言—— 1044:判断是否为两位数
    1043:整数大小比较
    1043:整数大小比较
    1043:整数大小比较
    排序算法 —— 插入排序
    排序算法 —— 插入排序
    排序算法 —— 插入排序
    C#中如何获取一个字体的宽度值(像素单位)
    visual studio 恢复默认界面
    visual studio 恢复默认界面
  • 原文地址:https://www.cnblogs.com/idjl/p/9610553.html
Copyright © 2011-2022 走看看