前言

曾经屏幕适配一直是个头疼的问题,各种坑,各种浏览器&设备兼容问题,好在的是,随着技术&标准的不断发展,这个问题得到了极大程度的解决,这篇文章主要对之前开发过程中的屏幕适配问题做个的简单总结,包括两个部分。

长屏适配

得益于CSS样式中vh&vw单位的支持普及,终于可以放心大胆的使用了,避免使用相对繁琐的scaleemrem

如图所示:

vh:将window.innerHeight分成100份,即1vh等于window.innerHeight1%

vw:将window.innerWidth分成100份,即1vw等于window.innerWidth1%

注意:长度包括滚动条

注意:长度包括滚动条

注意:长度包括滚动条

然后,我们就可以放心的使用vw当做长度单位来进行排版啦,因为在长屏的情况下,高度我们不在意(因为高度随页面内容变化),而元素会随着宽度的变化而变化。

以750x1334的设计稿为例,750/100=7.5px,那么1vw=7.5px,在排版的时候,根据这个单位换算即可。

简单示例如下:传送门

<!doctype html>
<html lang="zh-CN"> <head>
<meta charset="utf-8">
<meta http-equiv="x-ua-compatible" content="ie=edge">
<title></title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="https://cdn.bootcss.com/normalize/7.0.0/normalize.min.css" rel="stylesheet">
<style>
html,
body {
height: 100%;
background-color: lightgray;
} .container {
width: 100vw margin: 0 auto;
overflow: auto;
} .banner {
background-color: black;
height: 50vw;
margin: 2vw;
border-radius: 2vw;
} .row {
display: flex;
} .item {
flex: 1;
height: 46vw;
background-color: cornflowerblue;
margin: 2vw;
font-size: 4vw;
display: flex;
align-items: center;
justify-content: center;
}
</style>
</head> <body>
<div class="container">
<div class="banner">
</div>
<div class="row">
<div class="item">
列表项
</div>
<div class="item">
列表项
</div>
</div>
<div class="row">
<div class="item">
列表项
</div>
<div class="item">
列表项
</div>
</div>
<div class="row">
<div class="item">
列表项
</div>
<div class="item">
列表项
</div>
</div>
<div class="row">
<div class="item">
列表项
</div>
<div class="item">
列表项
</div>
</div>
</div>
</body> </html>

那么有同学可能有疑问了,vw%百分比有啥区别?在我看来,主要有2个。

1、百分比是定义基于包含块(父元素)宽度的百分比宽度,受到position属性的影响。而vw永远以浏览器可视区为基准。

2、百分比只能用于width和height,而vw可以用于任何以大小为单位的属性,例如font-size,这样就非常方便了。

单页适配

与长屏不同的是,类似单页H5小游戏,H5单页滚屏展示等,我们需要在屏幕内将页面完整的展现出来,这就没法使用vw了,因为我们需要根据设计图比例,保证单页完整动态计算和限制页面的展示大小展示,而vw无法做单一限制,这时js+百分比就派上用场了。

以微信中的单页活动展示为例,去掉64px的顶部导航,设计图定为750*1206。

有2种情况:

1、当屏幕宽度大于设计稿时

为了保证单页完整显示,需要以高度为基准,动态计算出宽度,居中显示

2、当屏幕宽度小于设计稿时

为了保证单页完整显示,需要以宽度为基准,动态计算出高度,居中显示

字体大小,也可根据缩放比例,动态计算px

示例代码如下:传送门

<!doctype html>
<html lang="zh-CN"> <head>
<meta charset="utf-8">
<meta http-equiv="x-ua-compatible" content="ie=edge">
<title></title>
<meta name="description" content="">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link href="https://cdn.bootcss.com/normalize/7.0.0/normalize.min.css" rel="stylesheet">
<style>
html,
body {
width: 100%;
height: 100%;
background-color: lightgray;
} .wrapper {
background: url('./img/timg.jpg') no-repeat center;
background-size: cover;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
margin: 0 auto;
} .container {
position: relative;
height: 100%;
} .banner {
height: 30%;
background-color: bisque;
flex: 1;
display: flex;
align-items: center;
justify-content: center;
margin: 2%;
} .row {
display: flex;
justify-content: center;
align-items: center;
margin: 2%;
height: 32.5%;
} .item {
flex: 1;
display: flex;
align-items: center;
justify-content: center;
background-color: pink;
height: 100%;
}
</style>
</head> <body>
<div class="wrapper">
<div class="container">
<div class="banner">
banner
</div>
<div class="row">
<div class="item" style="margin-right: 1%">
列表项
</div>
<div class="item" style="margin-left: 1%">
列表项
</div>
</div>
<div class="row">
<div class="item">
列表项
</div>
</div>
</div>
</div>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script>
var fontSize = $('html').css('font-size').slice(0, -2); function measureArea() {
var height = $(window).height();
var width = $(window).width(); var temp_width = height * 10 / 16;
if (temp_width < width) {
$('.container').css('width', temp_width + 'px');
$('.wrapper').css('max-width', temp_width + 'px');
} else {
$('.container').css('width', width + 'px');
$('.container').css('height', width * 16 / 10 + 'px');
$('html').css('font-size', fontSize * (width / temp_width) + 'px');
}
}
window.onresize = measureArea;
measureArea();
</script>
</body> </html>

参考

https://developer.mozilla.org/en-US/docs/Web/CSS/length#vw

https://github.com/amfe/lib-flexible

https://www.w3cplus.com/css/vw-for-layout.html

那些H5用到的技术(6)——屏幕适配的更多相关文章

  1. 那些H5用到的技术(3)——屏幕场景滑动

    前言Swiper.js一些需要我们手动设置的参数排版元素需要设置position:absolute绝对元素定位swiperAnimate方法的使用动画播放完成之后的监听上滑提示屏幕适配的问题Anima ...

  2. 那些H5用到的技术(1)——素材加载

    编码环境前言什么时候用到素材加载?loading提示,让用户等待图片的加载音频的加载利用神器PreloadJS总结 编码环境 Sublime Text 3 插件包括: Autoprefixer 自动补 ...

  3. Android 开发中的屏幕适配技术详解

    本文主要介绍Android开发中比较头疼繁琐的一个问题-屏幕适配问题.主要从适配原因.基本核心概念.适配方法等方面介详细 介绍从而是的深入或者进一步对Android屏幕适配技术的掌握和理解. 真题园网 ...

  4. H5的本地存储技术及其与Cookie的比较

    第一部分: H5的本地存储技术 HTML5 提供了两种在客户端存储数据的新方法.先看下面的例子: 例1:var mySelection = {name:"car", amount: ...

  5. h5移动端屏幕适配

    1.rem <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  6. 关于h5屏幕适配

    1)使用rem进行等比缩放 rem作用于非根元素时,相对于根元素字体大小:rem作用于根元素字体大小时,相对于其出初始字体大小 比如根元素(html)设置font-size=12px; 非根元素设置w ...

  7. iOS屏幕适配

    ## iOS屏幕适配 ### iOS屏幕适配发展史 1> iPhone4以前(没有iPad) * 不需要屏幕适配 2> iPad.iPhone5等设备出现 * 需要做横竖屏适配 * aut ...

  8. 【移动适配】移动Web怎么做屏幕适配(三)

    复杂纷扰的世界背后,总会有万变不离其宗的简单规则 啃先生 Mar.8th.2016 壹 | Fisrt 前面写了两篇移动适配相关的文章: <移动Web怎么做屏幕适配(一)>重点介绍了怎样利 ...

  9. 【收藏】Android屏幕适配全攻略(最权威的Google官方适配指导)

    来源:http://blog.csdn.net/zhaokaiqiang1992 更多:Android AutoLayout全新的适配方式, 堪称适配终结者 Android的屏幕适配一直以来都在折磨着 ...

随机推荐

  1. Javascript变长参数和默认参数

    /* javascript 变长参数 * 实参少于形参: 剩下的参数如果没有默认值,将解析为undefined * 实参多于形参: 剩下的实参可以通过 "实参对象"-argumen ...

  2. 视觉SLAM的数学基础 第一篇 3D空间的位置表示

    视觉SLAM中的数学基础 第一篇 3D空间的位置表示 前言 转眼间一个学期又将过去,距离我上次写<一起做RGBD SLAM>已经半年之久.<一起做>系列反响很不错,主要由于它为 ...

  3. 20155308 2016-2017-2 《Java程序设计》第8周学习总结

    20155308 2016-2017-2 <Java程序设计>第8周学习总结 教材学习内容总结 第十四章 NIO与NIO2 NIO(New IO)-from JDK1.4 NIO2 -fr ...

  4. ETL开发

    要进入开发阶段,了解不同的ETL产品. 整个ETL系统中,时间或更精确的,吞吐量是主要关心的内容.这种转换处理任务设计的主要目的归根结底是使得数据装载到展现表中最快并使得最终用户能快速的从这些表中得到 ...

  5. Android-自定义侧滑菜单

    效果图: 需要继承ViewGroup,因为包含了子控件,菜单子控件 与 主页面子控件 Activity Xml布局相关: <!-- 自定义侧滑菜单 SlideMenu --> <Li ...

  6. kubernetes 滚动更新发布及回滚

    基本命令 记录历史 --record kubectl  apply -f **** --record 查看当前状态 kubectl rollout status deployment/demo -w ...

  7. Spring中ApplicationContext和beanfactory区别---解析二

    一.BeanFactory 和ApplicationContext Bean 工厂(com.springframework.beans.factory.BeanFactory)是Spring 框架最核 ...

  8. Visual Studio Code 基本操作 - Windows 版

    1.Install the .NET SDK 2.Create app: dotnet new console -o myApp cd myApp 3.Run your app:dotnet run

  9. 记录---IIS显示asp.net程序的具体错误

    原来IIS设置成显示单一的错误页面 但是最近的服务器页面报错,但是本地确实完好的:所以想着让服务器显示具体的报错 网上找到两种方法: 先说第一种有效的: 通过 web.config 配置 其实,上面在 ...

  10. 写了一个Windows服务,通过C#模拟网站用户登录并爬取BUG列表查询有没有新的BUG,并提醒我

    写了一个Windows服务,通过C#模拟网站用户登录并爬取BUG列表查询有没有新的BUG,并提醒我 1.HttpUtil工具类,用于模拟用户登录以及爬取网页: using System; using ...