写点什么

【值得收藏】HTML5 使用多种方法实现移动页面自适应手机屏幕的方法总结

作者:迷彩
  • 2022 年 6 月 30 日
  • 本文字数:1516 字

    阅读完需:约 5 分钟

前言

随机智能手机,平板等智能移动设备的普及。移动端是我们目前接触最多的页面展示终端,不管是对于开发者还是其他普通的使用者都是普遍的存在,而且移动终端的使用比电脑更广泛,更频繁,特别是当微信平台等变成我们日常使用工具之后。所以对于开发者来说,不管任何开发任何界面都需要着重考虑页面对移动设备的兼容以及自适应。才能让用户体验性更好。


1、使用 meta 标签:viewport

H5 移动端页面自适应普遍使用的方法,理论上讲使用这个标签是可以适应所有尺寸的屏幕的,但是各设备对该标签的解释方式及支持程度不同造成了不能兼容所有浏览器或系统。

viewport 是用户网页的可视区域。翻译为中文可以叫做"视区"。

手机浏览器是把页面放在一个虚拟的"窗口"(viewport)中,通常这个虚拟的"窗口"(viewport)比屏幕宽,这样就不用把每个网页挤到很小的窗口中(这样会破坏没有针对手机浏览器优化的网页的布局),用户可以通过平移和缩放来看网页的不同部分。

viewport 标签极其属性:

代码如下:

<meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>
复制代码


2、使用 css3 单位 rem

rem 是 CSS3 新增的一个相对单位(root em,根 em),使用 rem 为元素设定字体大小时,是相对大小,但相对的只是 HTML 根元素。通过它既可以做到只修改根元素就成比例地调整所有字体大小,又可以避免字体大小逐层复合的连锁反应。

目前,除了 IE8 及更早版本外,所有浏览器均已支持 rem。对于不支持它的浏览器多写一个绝对单位的声明。这些浏览器会忽略用 rem 设定的字体大小。下面就是一个例子:

p {font-size:14px; font-size:.875rem;}
复制代码

默认 html 的 font-size 是 16px,即 1rem=16px,如果某 p 宽度为 32px 你可以设为 2rem。

通常情况下,为了便于计算数值则使用 62.5%,即默认的 10px 作为基数。当然这个基数可以为任何数值,视具体情况而定。设置方法如下:

Html{font-size:62.5%(10/16*100%)}
复制代码

具体不同屏幕下的规则定义,即基数的定义方式:可以通过 CSS 定义,不同宽度范围里定义不同的基数值,当然也可以通过 js 一次定义方法如下:

<script type="text/javascript">   (function (doc, win) {      var docEl = doc.documentElement,        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',        recalc = function () {          var clientWidth = docEl.clientWidth;          if (!clientWidth) return;          docEl.style.fontSize = 20 * (clientWidth / 320) + 'px';//其中“20”根据你设置的html的font-size属性值做适当的变化        };       if (!doc.addEventListener) return;      win.addEventListener(resizeEvt, recalc, false);      doc.addEventListener('DOMContentLoaded', recalc, false);    })(document, window);</script>
复制代码

3、使用媒体查询

媒体查询也是 css3 的方法,我们要解决的问题是适应手机屏幕,这个媒体查询正是为解决这个问题而生。

媒体查询的功能就是为不同的媒体设置不同的 css 样式,这里的“媒体”包括页面尺寸,设备屏幕尺寸等。

例如:如果浏览器窗口小于 500px, 背景将变为浅蓝色:

@media only screen and (max-width: 500px) {    body {        background-color: lightblue;    }}
复制代码

4、使用百分比

百分比指的是父元素,所有百分比都是这样的。子元素宽度 50%,那么父元素的宽度就是 100%;

所以 body 默认宽度是屏幕宽度(PC 中指的是浏览器宽度)子孙元素按百分比定位(或指定尺寸)就可以了,这只适合布局简单的页面,复杂的页面实现很困难。这也是我目前使用最普遍的一种方式,其实大多时候一种方法并不适合所有的效果,所以我们会根据实际效果几种方式结合使用


发布于: 刚刚阅读数: 5
用户头像

迷彩

关注

我的工作是常年写bug|公众号:编程架构之美 2020.06.18 加入

修bug的菜鸟~公众号:“互联网有啥事”已改名为“编程架构之美”

评论

发布
暂无评论
【值得收藏】HTML5使用多种方法实现移动页面自适应手机屏幕的方法总结_前端_迷彩_InfoQ写作社区