手机html根据手机分辨率网页文字大小自适应

2024-05-05 04:08

本文主要是介绍手机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 metaif (vpMeta) {console.warn("将根据已有的meta标签来设置缩放比例");var initial = vpMeta.getAttribute("content").match(/initial\-scale=([\d\.]+)/);if (initial) {scale = parseFloat(initial[1]); // 已设置的 initialScaledpr = parseInt(1 / scale);      // 设备像素比 devicePixelRatio}}// 设置了 flexible Metaelse 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 metaif (!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>

这篇关于手机html根据手机分辨率网页文字大小自适应的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/960784

相关文章

Android实现两台手机屏幕共享和远程控制功能

《Android实现两台手机屏幕共享和远程控制功能》在远程协助、在线教学、技术支持等多种场景下,实时获得另一部移动设备的屏幕画面,并对其进行操作,具有极高的应用价值,本项目旨在实现两台Android手... 目录一、项目概述二、相关知识2.1 MediaProjection API2.2 Socket 网络

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求