一、移动端页面布局

  1.移动端的屏幕尺寸

    移动端屏幕尺寸:屏幕对角线的长度,单位是英寸(1英寸=2.45厘米);

    常见的尺寸有:2.4,2.8,3.5,3.7,4.2,5.0,5.5,6.0

    

  2.屏幕的分辨率

    屏幕分辨率:指横纵方向上的像素点数,单位为px,1px=1像素点;

    一般以纵向像素*横向像素表示一个手机的分辨率;eg:1960*1080

    这里的一个像素是指物理设备的一个像素点

  3.屏幕像素密度

    屏幕像素密度:屏幕上每英寸可以显示像素点的数量,单位是ppi(pixels per inch)缩写

    屏幕像素密度与屏幕尺寸,屏幕分辨率有关,在单一条件下,屏幕尺寸越小,分辨率越高,像素密度越大,反之越小

    iPhone3GS和iPhone4区别:屏幕尺寸一样,屏幕分辨率相差一倍,屏幕像素密度也相差一倍

    

    PX:像素,将显示器分成非常细小的方格就是1px;

    注:网页重构中使用的px和分辨率的px不一定是一样的大小

    实际上像素分为两种:设备像素和逻辑像素(CSS像素)

    DPR:设备像素比DPR(devicePixelRatio)是默认缩放为100%的情况下,设备像素和css像素的比值

    在早先的移动设备中,并没有DPR的概念。随着技术的发展,移动设备的屏幕像素密度越来越高。从iphone4开始苹果公司推出了所谓的retina视网膜屏幕。之所以叫做视网膜屏幕,是因为屏幕的PPI(屏幕像素密度)太高,人的视网膜无法分辨出屏幕上的像素点。iphone4的分辨率提高了一倍,但屏幕尺寸却没有变化,这意味着同样大小的屏幕上,像素多了一倍,于是DPR = 2

  4.弹性布局(100%布局)

    特点:顶部与底部的bar不管分辨率怎么变,他的高度和位置都不变;中间的信息都位于左边、右边的位置不会发生变化;

    

  5.等比缩放布局(rem布局)

    rem(font size of the root element):根据根元素字体大小的相对单位,默认情况下1rem=16px;

    逻辑像素:当前设备的分布率

    物理像素:当前设计稿的分布率

    因为我们通常情况下都是通过量出当前设计稿的宽度/高度来进行代码的编辑和书写,但是我们在预览的时候都是在当前设备上进行预览,因此就会出现一个倍率,这个倍率我们通常叫做dpr;在用rem布局移动端的时候我们需要在设计稿上量出当前元素的大小然后除以当前的dpr然后再除以更元素字体大小计算出rem

    特点:能够实现强大的屏幕适配布局;能等比例适配所有的屏幕,根据变化html的字体大小来控制rem的大小

  6.vw布局

    相对于视口宽度或高度的单位,1vw等于当前视口的1%;

    vw:viewpoint width,视窗宽度,1vw等于视窗宽度的1%;

    vh:viewpoint height,视窗高度,1vh等于视窗高度的1%;

    vmin:vw和vh中较小的那个;

    vmax:vw和vh中较大的那个;

    vw, vh, vmin, vmax:IE9+局部支持,chrome/firefox/safari/opera支持,iOS safari 8+支持,Android browser4.4+支持,chrome for android39支持

  7.用媒体查询设置html的font-size配合rem(设置判断条件的节点)

  8.通过JS(flexible.js)动态设置html的font-size同样元素单位也要配合rem实现等比例缩放布局

    注:调用js时把移动端设置的meta标签及设置的HTML的font-size删除

  9.rem结合vw布局

    VW转换成PX赋值给font-size

    例:设备的分辨率为640*1136,逻辑像素为320*568 1VW=3.2px

      Font-size:100px;转换成VW font-size:31.25vw;

      1rem=31.25vw可一起结合写等比例缩放布局

    使用rem结合vw布局时,iconfont会出现下移的问题,这是因为它自带行高,而跟元素设置的为100px,font-size属性具有继承性, 继承了跟元素的100px,而自身也就带有了100px的行高,需给他设置font-size属性,或者转为块元素,也可以给body设置font-size为16px

HTML学习笔记Day14的更多相关文章

  1. JS学习笔记Day14

    一.正则表达式 (一)正则的概念 1.正则表达式是一种特殊的字符串模式,用于匹配一组字符串,就好比用模具做产品,而正则就是这个模具,定义一种规则去匹配符合规则的字符 (二)创建正则的方式 1.字面量的 ...

  2. Python学习笔记 - day14 - Celery异步任务

    Celery概述 关于celery的定义,首先来看官方网站: Celery(芹菜) 是一个简单.灵活且可靠的,处理大量消息的分布式系统,并且提供维护这样一个系统的必需工具. 简单来看,是一个基于pyt ...

  3. 【目录】Python学习笔记

    目录:Python学习笔记 目标:坚持每天学习,每周一篇博文 1. Python学习笔记 - day1 - 概述及安装 2.Python学习笔记 - day2 - PyCharm的基本使用 3.Pyt ...

  4. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  5. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  6. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  7. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  8. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  9. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

随机推荐

  1. Java使用RabbitMQ之整合Spring(消费者)

    依赖包: <!--RabbitMQ集成spring--> <!-- https://mvnrepository.com/artifact/org.springframework.am ...

  2. LODOP循环多任务 同模版只设置不同队列任务名

    LODOP中从PRINT_INIT(或PRINT_INITA)到最后PRINT(或PREVIEW等),是一个任务,关于Lodop中一个任务,以及一个任务中可以包含哪些语句,详细可查看本博客另一篇博文: ...

  3. How to helloworld on Xcode

    create a mac app,click button to change label text? create project,click left window button on Main. ...

  4. DeepLearning训练方法

    1.BN层训练技巧 缩小输入尺寸,这样可以提高batchsize的大小,在BN层适应了该数据集后,固定住BN层参数,放大输入尺寸继续训练 2.语义分割中解决网络输出尺寸与原尺寸的gap方法(如 1/8 ...

  5. hdu1839(最小生成树)

    题意:字面意思: 思路:就是多了一个前提,有些点之间可能有边,有两个处理方法,一个是有边的,这条边权值归零,另一个是,先一次循环用并查集过一遍: 代码:(用的是第一种方法) #include<i ...

  6. Centos 7安装和配置 ElasticSearch入门小白

    实验环境: 操作系统:Centos 7.5 服务器ip:192.168.1.198 运行用户:root 网络环境:Internet 在企业生产环境有很多服务器的时候.很多业务模块的日志的时候运维人员需 ...

  7. windows环境pip安装时一直报错Could not fetch URL https://pypi.org/simple/xrld/: There was a problem confirming the ssl certificate: HTTPSConnectionPool(host='pypi.org', port=443): Max retries exceeded with url:

    最近项目不忙了~~有开始专研的python大业,上来想用pip安装一个第三方的库,就一直报错: Could not fetch URL https://pypi.org/simple/xrld/: T ...

  8. 基于FPGA的数字秒表(数码管显示模块和按键消抖)实现

    本文主要是学习按键消抖和数码管动态显示,秒表显示什么的,个人认为,拿FPGA做秒表真是嫌钱多. 感谢 感谢学校和至芯科技,笔者专业最近去北京至芯科技培训交流了一周.老师的经验还是可以的,优化了自己的代 ...

  9. IDEA 不识别的MAVEN 项目应如何处理

    有些人啊,上传到git的项目,根本不是项目而是一个文件夹,文件夹里边还有个文件夹那才是项目,IDEA 不会识别出它是项目来 这个时候,需要选择这个文件夹下的pom.xml 文件 右键 pom.xml然 ...

  10. 使用gradle命令代替CUBA Studio,启动项目

    在cuba platform开发中,一开始都会使用CUBA Studio,这是一个脚手架,可以很方便的创建数据表.视图.Bean等.但是有时也会有奇怪的问题,比如不能读取本地maven 仓库,只读取远 ...