移动端1px与viewport

layout viewport : 浏览器默认宽度,document.documentElement.clientWidth,iphone7 为 980;

visual viewport : 浏览器可视区域的大小,screen.width,iphone7 为 375;

ideal viewport : 移动端理想默认宽度,iphone 理想为375;不需要用户缩放和横向滚动条就能正常的查看网站的所有内容,比如一段14px大小的文字,不会因为在一个高密度像素的屏幕里显示得太小而无法看清,理想的情况是这段14px的文字无论是在何种密度屏幕;

设备物理像素:移动设备的屏幕像素密度;

设备独立像素:移动设备的屏幕宽度;

我们在不设置任何viewport的时候,我们的手机,比如iphone7,浏览器默认的宽度,为980px,会自动计算浏览器的缩放比例,以达到和设备独立像素相同的宽度375,相当于缩小了980/375倍;

<head>
        <title></title>
        <meta charset="UTF-8"/>
    </head>
    <body>
        <div style="width: 200px;height: 300px; border: 1px solid #000;">
            这是在不设置viewprot后的200px
        </div>
    </body>
页面被缩小.png

但当我们设置了

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

相当于把浏览器的宽度即layout viewport等于设备的宽度,本来980的,变为375;
这个时候,因为浏览器和设备的独立像素相同,自动计算浏览器的缩放比为1:1,不会发生缩小;

页面没有被缩小.png

这个时候就会引进一个问题了,我们在设置1px的时候,在高清屏中,比如iphone7,会用两个物理像素来渲染;

设备物理像素和逻辑像素(设备独立像素),其实这两个px的含义其实是不一样的,UI设计师要求的1px是指设备物理像素1px,而CSS里记录的像素是逻辑像素(设备独立像素或者浏览器可见宽度)。

在视网膜屏幕的iphone上,屏幕物理像素640像素,独立像素还是320像素,因此,window.devicePixelRatio等于2;

正常情况下,border 1px的逻辑像素,在高清屏之中是用了2px的物理像素来显示;

viewport

移动端开发常需要在html的header里添加如下一句:

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

这句话定义了浏览器的宽度为设备宽度,页面的初始缩放值和最大缩放值都为1,并禁止了用户缩放。

viewport : 设备屏幕上能用来显示我们网页内容的那一块区域;

width=device-width:把当前浏览器的宽度设置为设备独立像素宽度;

initial-scale=1.0:页面相对于设备独立像素缩放比例;

maximum-scale=1.0、minimum-scale=1.0 同上;

user-scalable : no; 禁止用户手动缩放;用户缩放的尺度越大,1px用的设备物理像素越大;

物理像素显示1px方法

主要都是通过缩放解决

1、viewport动态的修改页面的缩放比例

全局修改

var viewport = document.querySelector("meta[name=viewport]")
if (window.devicePixelRatio == 1) {
    viewport.setAttribute('content', 'width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no')
} 
if (window.devicePixelRatio == 2) {
    viewport.setAttribute('content', 'width=device-width, initial-scale=0.5, maximum-scale=0.5, minimum-scale=0.5, user-scalable=no')
} 
if (window.devicePixelRatio == 3) {
    viewport.setAttribute('content', 'width=device-width, initial-scale=0.333333333, maximum-scale=0.333333333, minimum-scale=0.333333333, user-scalable=no')
} 

即将浏览器在相同的宽度(width=device-width)下,页面缩放了一半或者1/3来显示,border也小了一半;

缺点:适用于项目,比如有些旧项目写了某个节点字体大小为2rem,750px中1rem = 100px时,2rem为200px,但是经过0.5缩放,要显示为200px时候,就要修改css的属性为4rem了,而且改动的地方是很多的;

2、transform: scale(0.5) 推荐

直接缩放需要设置的元素

用::after设置border:1px solid #000; width:200%; height:200%,然后再缩放scaleY(0.5); 优点可以实现圆角,京东就是这么实现的,缺点是按钮添加active比较麻烦。

.border {
    position: relative;
}
.border::after {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid #bfbfbf;
    border-radius: 4px;
    -webkit-transform-origin: top left;
}
/* 2倍屏 */

@media only screen and (-webkit-min-device-pixel-ratio: 2.0) {
    .border::after {
        width: 200%;
        height: 200%;
        -webkit-transform: scale(0.5);
        transform: scale(0.5);
    }
}
/* 3倍屏 */

@media only screen and (-webkit-min-device-pixel-ratio: 3.0) {
    .border::after {
        width: 300%;
        height: 300%;
        -webkit-transform: scale(0.33);
        transform: scale(0.33);
    }
}

其他方法

box-shadow 方案、background-image 渐变实现、设置 border-image 方案、媒体查询利用设备像素比缩放,设置小数像素

都会有圆角或者不支持的情况,不做描述;

结语:

1、当我们不设置任何viewport 属性时,移动端浏览器会自动缩放到和设备独立像素一直的宽度;

2、width=device-width:把当前浏览器的宽度设置为设备独立像素宽度,当浏览器和设备的独立像素相同时,不会发生缩放;

3、initial-scale 相当于我们在pc chrome中,用滚轮缩放页面一个道理;

4、解决1px的问题主要通过缩放解决;

参考:

meta name="viewport" content="width=device-width,initial-scale=1.0" 解释

移动端1像素边框问题

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

推荐阅读更多精彩内容