文章地址:

viewport移动端适配

笔记:

  1. 移动端适配目的:

    希望在屏幕尺寸大小不同的手机上进行访问页面时,页面显示的效果能合理的展示,我们期望的是在手机屏幕较大时显示的内容比较大一些,手机屏幕小的时候页面的内容也会缩小进行自适应。

  2. 手机端适配代码

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

不允许缩放,初始缩放值为1,最大缩放值为1,最小缩放值为1

目的?

让页面的宽度等于设备宽度,实际上,它就是设置了理想视口,将布局视口的宽度设置成了理想视口(浏览器/设备屏幕的宽度)。

3.适配的几种方案

1.css3媒体查询,pass
优点:
方法简单,只需修改css文件
调整屏幕宽度时不用刷新页面就可以响应页面布局
缺点:
代码量大,不方便维护
不能够完全适配所有的屏幕尺寸,需要编写多套css样式 2.百分比布局方案
那么需要清楚一个问题,各个子元素或属性的百分比是根据谁来设定呢?
1. 子元素width、height的百分比:子元素的width或height中使用百分比,是相对于子元素的直接父元素
2. margin和padding的百分比:在垂直方向和水平方向都是相对于直接父亲元素的width,而与父元素的height无关
3. border-radius的百分比:border-radius的百分比是相对于自身宽度,与父元素无关 优点:
宽度自适应,在不同的分辨率下都能达到适配
缺点:
百分比的值不好计算
需要确定父级的大小,因为要根据父级的大小进行计算
各个属性中如果使用百分比,相对父元素的属性并不是唯一的
高度不好设置,一般需要固定高度 3. rem方案 <script type="text/javascript">
(function() {
var deviceWidth = document.documentElement.clientWidth;
deviceWidth = deviceWidth < 320 ? 320 : deviceWidth > 640 ? 640 : deviceWidth;
document.documentElement.style.fontSize = deviceWidth / 7.5 + 'px';
})();
</script> 优点:
rem单位是根据根元素font-size决定大小,只要改变font-size的值,以rem为固定单位的元素大小也会发生响应式的改变 缺点:
必须通过一段js代码控制font-size的大小
控制font-size的js代码必须放在在页面第一次加载完成之前,并且放在引入的css样式代码之前。 4. vm、vh
vw 相对于视口的宽度,视口宽度是100vw
vh 相对于视口的高度,视口宽度是100vh
vmin vw和vh中较小的值
vmax vw和vh中较大的值 优点:
指定vw\vh相对与视口的宽高,由px换算单位成vw单位比较简单
通过postcss-px-to-viewport插件进行单位转换比较方便 缺点:
直接进行单位换算时百分比可能出现小数,计算不方便
兼容性- 大多数浏览器都支持、ie11不支持
少数低版本手机系统 ios8、android4.4以下不支持 最后,有一个问题,既然百分比和vw都是需要计算百分比,那么两个方案的不同之处?
% width、height等大部分相对于直接父元素、border-radius、translate、background-size等相对于自身
vw 只相对于视口宽度

4.现在的工作团队是怎么获取font-size的?怎么做页面适配的?

(function (doc, win) {
var recalc = function () {
var docEl = document.getElementsByTagName("html")[0];
var bodyEl = document.getElementsByTagName("body")[0];
/*
var obj = { 320:1, 360:1, 375:1, 400:1, 414:1, 440:1, 480:1
, 520:1, 560:1, 600:1, 640:1, 680:1, 720:1
, 760:1, 800:1, 960:1, 1440:1, 1280:1,1920:1,1080:1
};
if(obj[docEl.clientWidth]) {
return;
}
*/
var clientWidth = docEl.clientWidth;
if (!clientWidth) {return;}
docEl.style.fontSize = clientWidth/10 + 'px';
bodyEl.style.maxWidth = clientWidth + 'px';
};
recalc();
if (!doc.addEventListener) return;
var resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';
win.addEventListener(resizeEvt, recalc, false);
doc.addEventListener('DOMContentLoaded', recalc, false);
})(document, window);

恩,没啥可特别的,之前还考虑了手机横屏后的效果,现在都屏蔽了,就记住网上的写法就好,恩!

viewport移动端适配,读文笔记的更多相关文章

  1. WEB 前端模块化,读文笔记

    文章链接 WEB 前端模块化都有什么? 知识点 根据平台划分 浏览器 AMD.CMD 存在网络瓶颈,使用异步加载 非浏览器 CommonJS 直接操作 IO,同步加载 浏览器 AMD 依赖前置 req ...

  2. 移动端适配(rem & viewport)--移动端开发整理笔记(四)

    移动端适配 通过rem适配 em: 根据元素自身的字体大小来计算自己的尺寸 rem: (root em) 根据根节点(html)的字体大小来计算自己的尺寸   我们知道,在不同的手机设备,分辨率大小是 ...

  3. web开发中移动端适配

    这个话题有些复杂,说起来有些琐碎,因为和移动端适配相关的问题太多了. 1. 概念 1.1 设备像素 设备像素被称为物理像素,它是显示设备中一个最小的物理部件.每个像素可以根据操作系统设置自己的颜色和亮 ...

  4. 【前端】移动端Web开发学习笔记【1】

    下一篇:移动端Web开发学习笔记[2] Part 1: 两篇重要的博客 有两篇翻译过来的博客值得一看: 两个viewport的故事(第一部分) 两个viewport的故事(第二部分) 这两篇博客探讨了 ...

  5. 移动端适配单位rem

    0 写在前面 本周惊喜地发现,其他各个老师的软工班(罗杰老师班和欧阳老师班)的软工项目的alpha版本都已经发布了!(然而我们软工项目还没开始写代码…逃…) 十分好奇的我第一时间下载了一些他们的产品进 ...

  6. web前端--移动端适配总结

    转自:https://segmentfault.com/a/1190000011586301 作者:Devinnn meta标签到底做了什么事情 做过移动端适配的小伙伴一定有遇到过这行代码: < ...

  7. 移动端适配 rem

    前置知识: 物理像素(physical pixel,device pixel) 物理像素(设备像素),显示设备中一个最微小的物理部件.每个像素可以根据操作系统设置自己的颜色和亮度. 设备独立像素(de ...

  8. mui初级入门教程(六)— 模板页面实现原理及多端适配指南

    文章来源:小青年原创发布时间:2016-07-26关键词:mui,webview,template,os,多端适配转载需标注本文原始地址: http://zhaomenghuan.github.io. ...

  9. 超详细讲解H5移动端适配

    前言 移动互联网发展至今,各种移动设备应运而生,但它们的物理分辨率可以说是五花八门,一般情况UI会为我们提供375尺寸的设计稿,所以为了让H5页面能够在这些不同的设备上尽量表现的一致,前端工程师就不得 ...

随机推荐

  1. 洛谷 - P4452 - 航班安排 - 费用流

    https://www.luogu.org/problemnew/show/P4452 又一道看题解的费用流. 注意时间也影响节点,像题解那样建边就少很多了. #include<bits/std ...

  2. EOJ3247:铁路修复计划

    传送门 题意 分析 这题用二分做就好啦,有点卡常数,改了几下for的次数 套了个板子,连最小生成树都忘记了QAQ trick 代码 #include<cstdio> #include< ...

  3. hdoj5821【贪心-神题】

    啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊,比赛的时候直接读错题了,实力带坑队友.... 题意: 有两个序列都代表筐,每个筐里只有一个球,然后序列的值代表筐里的球的颜色,问你在m次操作后,a序列的球能否变成b ...

  4. IT兄弟连 JavaWeb教程 请求重定向案例

    Check2Servlet类与Output2Servlet类之间为请求转发关系.在web.xml文件中,为Check2Servlet映射的URL为"/check2",为Output ...

  5. oauth2(spring security)报错method_not_allowed(Request method 'GET' not supported)解决方法

    报错信息 <MethodNotAllowed> <error>method_not_allowed</error> <error_description> ...

  6. Java对象的内存布局以及对象的访问定位

    一 Java对象的内存布局 在HotSpot虚拟机中,对象在内存中的布局分为3个区域 对象头(Header) Mark Word(在32bit和64bit虚拟机上长度分别为32bit和64bit)存储 ...

  7. 多个版本数据库在在一台数据库上lib 的切换问题。

    lib 的切换问题. 现象: /home/dbmon  >sqlplus / as sysdba/usr/lib/hpux64/dld.so: Unsatisfied data symbol ' ...

  8. 堆参数-XMS 与-XMX的说明

    XMS : JVM初始分配的堆内存 XMX : JVM最大允许分配的堆内存,按需分配 堆内存分配: JVM初始分配的堆内存由-Xms指定,默认是物理内存的1/64: JVM最大分配的堆内存由-Xmx指 ...

  9. 动手实现 Redux(一):优雅地修改共享状态

    从这节起我们开始学习 Redux,一种新型的前端“架构模式”.经常和 React.js 一并提出,你要用 React.js 基本都要伴随着 Redux 和 React.js 结合的库 React-re ...

  10. 基于ABP的Easyui admin framework正式开放源代码

    下载&反馈:http://www.webplus.org.cn v1.0 (2016/9/21) EF6+MVC5+API2+Easyui1.4.2开发 后台管理不使用iframe,全ajax ...