手机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

相关文章

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库