移动适配布局

1.像素相关

1.1 设备像素(物理像素)

1.显示器的最小物理单位(对于一个显示器来说是固定的)
2.以手机屏幕为例,屏幕上的真实像素点。iphone6 的设备像素 750 * 1334
3.通常说的4k显示屏指的是4096×2160

1.2 设备独立像素(独立像素)

1.通常通过window.screen.width/window.screen.height查看。
2.操作系统定义的长度单位。iPhone的设备独立像素。

1.3 CSS像素

1.CSS中的长度的单位,在CSS中使用的px都是只CSS像素。
2.在页面不缩放的情况下。1px的CSS像素===1设备独立像素。
3.页面放大200%时,页面的设备独立像素依旧不变,放的的是CSS像素,但此时的CSS像素与设备独立像素的关系变化了,1px === 4独立像素(宽×2,高×2)

1.4 PPI

1.指每英寸的物理像素数
2.以尺寸为5.8英寸(屏幕对角线长度)屏幕对角线上的像素点/对角线的英寸数

1.5 devicePixelRatio 设备像素比(dpr)

1.devicePixelRatio指的是物理像素和设备独立像素的比 即1独立像素由多少物理像素渲染。
2.window.devicePixelRatio 可查看
3.window.devicePixelRatio = 物理像素 / 独立像素

1.6解决移动端1像素的问题

因为不同设备具有不同的drp,所以css 1px所代表的设备像素不同,所以在有些设备上看到的粗,有些设备看到的细,如何解决一像素边框问题。

方法一:
通过媒体查询,查询设备的dpr,根据dpr设置不同的宽度大小

   #box{
        height: 200px;
        border-bottom: 1px solid red;
    }

    @media screen  and(-webkit-min-device-pixel-ratio: 2) {
        #box{
            border-bottom: 0.5px solid #999;
        }
    }

    @media  screen and (-webkit-min-device-pixel-ratio: 3)  {
        #box{
            border-bottom: 0.3333px solid blue ;
        }
    }

缺点:小数像素目前兼容性较差,一些以前的版本不支持.
理论上最小的单位是 1px. 所以会出现有的设备写0.5px无效(没有边框)的情况.

方法二:
借助伪元素缩放处理

.button:after{
    content: "";
    display: block;
    height: 0;
    border-top: #999 solid 1px;
    width: 100%;
    position: absolute;
    top: 0;
    right: 0;
    transform: scaleY(0.5); /*将1px的线条缩小为原来的50%*/
}

缺点: 不是所有设备的dpr都是2 所以固定缩放0.5 也会有问题

方法三:
借助媒体查询和伪元素来解决

// 定义mixin
.border-1px(@color: rgba(7,17,27,0.2)){
    position:relative;
    &:after{
        display:block;
        position:absolute;
        left:0;
        bottom:0;
        content:'';
        width:100%;
        border-top:1px solid @color;
    }
}

// 根据不同的dpr 使用不同的缩放
@media (-webkit-min-device-pixel-ratio: 1.5),(min-device-pixel-ratio: 1.5){
    .border-1px {
        .border-1px;
        &:after {
            -webkit-transform: scaleY(0.7);
            -moz-transform: scaleY(0.7);
            -ms-transform: scaleY(0.7);
            -o-transform: scaleY(0.7);
            transform: scaleY(0.7);
        }
    }
}

@media (-webkit-min-device-pixel-ratio: 2),(min-device-pixel-ratio: 2){
    .border-1px {
        .border-1px;
        &:after {
            -webkit-transform: scaleY(0.5);
            -moz-transform: scaleY(0.5);
            -ms-transform: scaleY(0.5);
            -o-transform: scaleY(0.5);
            transform: scaleY(0.5);
        }
    }
}

@media (-webkit-min-device-pixel-ratio: 3),(min-device-pixel-ratio: 3){
    .border-1px {
        .border-1px;
        &:after {
            -webkit-transform: scaleY(0.3);
            -moz-transform: scaleY(0.3);
            -ms-transform: scaleY(0.3);
            -o-transform: scaleY(0.3);
            transform: scaleY(0.3);
        }
    }
}

2.viewport

2.1 什么是视口

通过<meta>标签进行设置,name属性指定viewport的值,content属性进行视口配置

取值 含义
width 设置layout view(布局视图)的宽度为特定值 device-width表示设备的宽度
height 设置layout view 的宽度为特定值 一般不设置
initial-scale 设置页面初始缩放
minmum 设置页面最小缩放
maximun 设置页面的最大缩放
user-scale 设置页面的最大缩放

3.适配

3.1 为什么要是配

a) 为了适应各种移动端设备,完美呈现应有的布局效果
b) 各个移动端设备,分辨率大小不一致,页面想铺满整个屏幕,并在各种分辨下等比缩放

现在主流的开发思路
1.PC端和移动端分开开发
2.如果想既能适应PC,又能适应移动端 响应式开发(麻烦 写好多套css)

3.2 自适应适配方案(布局方案)
3.2.1 先了解一些单位
  1. em:相对单位 1em等于当前元素的font-size值
  2. rem 相对单位 r -> root根节点(html)根据html字体大小设计其他元素尺寸
    1rem 就是html的font-size值
  3. vw/vh:吧屏幕分为100份,1vw就等于平米宽度的1%
3.2.2 媒体查询

media queries的方式可以说是早期用的布局方式,他主要是通过查询设备的宽度来执行不同的css代码,最终达到界面的配置.核心语法是:

@media screen and (max-width: 600px) { /*当屏幕尺寸小于600px时,应用下面的CSS样式*/
  /*你的css代码*/
}

优点

  1. 方法简单,成本低,特别是对移动和PC维护同一套代码的时候
  2. 调整屏幕宽度的时候不用刷新页面即可响应式展示

缺点

  1. 代码量比较大,维护不方便
  2. 为了兼顾大屏幕或高清设备,会在成其他设备资源浪费,特别是加载图片资源
  3. 为了兼顾移动端和PC端各自响应式的展示效果,难免会损失个子特有的交互方式
3.2.3百分比与Flex布局

布局的特性:关键元素高度和位置都不变,只有容器元素在伸缩变换
这种布局是一种典型的弹性布局

布局的方式:

  1. 布局盒子采用百分比
  2. 容器盒子与文字采用固定大小
  3. Flex确定位置(也可以采用浮动)

优缺点:

1.好处:大屏下可以展示更多的内容
2.坏处:宽屏下比例会比较不协调

注意: 这种情况下css尺寸单位用px就好,不要用rem,避免增加复杂度

3.2.4 rem布局

布局的特性:关键元素盒子大小与文字都随着屏幕大小不同,而展示不同的大小

布局方式:

1.根据屏幕大小不同设置html不同的字体大小
2.所有的盒子尺寸和文字大小采用rem布局方式

动态设置font-size

设置方式

var fontSize= document.documentElement.clientWidth /3.75
document.documentElement.style.fontSize = fontSize + 'px'

字体也可以不使用rem单位(通常也不建议字体用rem单位),采用不同的媒体方式

@media screen and (max-width:321px){
    .basesize{font-size:15px}
}

@media screen and (min-width:321px) and (max-width:400px){
    .basesize{font-size:16px}
}

@media screen and (min-width:400px){
    .basesize{font-size:18px}
}

如果值是希望盒子根据屏幕大小不同而改变,可以在body重新固定文字大小

body{
        font-size:16px;
}
3.2.5 缩放布局

固定高度宽度,文字大小 通过改变缩放比例适配
根据屏幕的分辨率动态设置适配缩放比例,达到等比缩放的功能

根据dpr来设置不同viewport缩放比例

// 改变视口的缩放比例
(function(){
    // 方法一
    var width = window.screen.width;
    var fixedW = 375;
    var scale = width / fixedW;
    var meta = document.createElement('meta');
    meta.setAttribute('name','viewport');
    meta.setAttribute('content',`width=${fixedW},initial-scale=${scale},minimun-sacle=${scale},maximun-scale=${scale},user-scalable=no`);
    document.head.appendChild(meta);
})()

如果是double设计图

// 改变视口的缩放比例
(function(){
    // 方法一
    var width = window.screen.width;
    var fixedW = 375;
    var scale = width / fixedW * 0.5;
    var meta = document.createElement('meta');
    meta.setAttribute('name','viewport');
    meta.setAttribute('content',`width=${fixedW},initial-scale=${scale},minimun-sacle=${scale},maximun-scale=${scale},user-scalable=no`);
    document.head.appendChild(meta);
    
})()
3.3通过vw设置html字体

以iphone6为例375px=100vw 1vw=3.75
如果我设置html的字体大小是100px

htl{
  font-size:26.666667vw
}

如果切换到iphone 6plus 1vw = 4.41px
注意要给body重置一下font-size:16px;

3.4 其他小技巧
3.4.1 固定比

三栏布局

利用box-sizing

#box{
  position:relative;
  width:100%;
  height:60px;
}
#box .left{
  position:absolute;
  top:0;
  left:0;
  width:60px;
  height:100%;
  background-color:red;
}
#box .content{
  width:100%;
  height:100%;
  background:blue;
  padding:0 60px;
  box-sizing:border-box;
}
#box .right{
  position:absolute;
  top:0;
  right:0;
  width:60px;
  height:100%;
  background:yellow;
}

利用flex

#box{
    width: 100%;
    height: 60px;
    display:flex;
}
#box .left{
    width:60px;
    height: 100%;
    background-color: red;
}
#box .content{
    flex:1;
    height: 100%;
    background-color: blue;
}
#box .right{
    width:60px;
    height: 100%;
    background-color: yellow;
}
3.4.2 设置高度按比例变换

1.不设置高度

不设置高度,图片宽度100%,高度默认按比例缩放

2.采用padding-top给盒子设置自动,然后用背景图

借用padding-top来处理,我们知道padding也可以显示背景

width:60%;
height:0;
padding-top:60%;

padding-bottom也可以,但是padding-top更好一点,overflow:hidden;隐藏超出的部分

3.通过js

var boxWidth = parseInt(getComputedStyle(box)['width']);
box.style.height = boxWidth+'px'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351