此处设置一个默认分辨率 1920*1080 , 设备尺寸15.6吋. (通常笔记本尺寸和分辨率)css
默认dpi(win屏幕通常为72或96dpi) (PS默认新建文档默认值72, 72通常在网络上传输,300dip用于输出打印)html
当设备的分辨率和设备尺寸不变的状况下,设备屏幕dpi(win屏幕通常为72或96dpi)在高于某个值(72或96dpi)的时候。屏幕的dpi就会影响网页缩放(从而影响网页布局)ios
屏幕dpi是如何变化的呢?
默认状况下:设备尺寸太小 , 分辨率太高致使设备dpi大于每英寸/72像素, windows会自动对屏幕显示进行放大 . 进而致使浏览器展现的网页被放大 (从而致使网页中、字体、元素尺寸变大,致使网页布局错乱)。windows
开发者为了调试在不一样dpi下网页的缩放和布局故意更改设备dpi。 浏览器
win10 调整dpi
网络
125%、150%、175%、200%、300%表明放大等级,数值会由 windows系统自动设置,同时本身也可手动设置。布局
苹果手机4s之后与苹果电脑retina屏 都表明着 系统dpi大于72或96或115dpi。
附经常使用尺寸表以及dpi https://uiiiuiii.com/screen/
默认状况下,手机的尺寸较小,分辨率过大(1080或2k)致使设备dpi很是高(通常400以上)因此这就致使了网页在手机上字体会被放大测试
解决方案
设置CSS 媒体查询
@media screen
根据不一样的分辨率和dpi来改变网页:字体、尺寸、和HTML排列方式。达到兼容不一样分辨率和同一分辨率下dpi不一样的网页兼容。字体
css设置同dpi下,不一样分辨率区间改变HTML布局达到兼容
@media screen and (min-width: 990px/*起始最小宽度*/) and (max-width: 1200px/*结束最大宽度*/){
/*样式书写处*/
}
css设置同分辨率下,不一样dpi改变网页、字体大小、元素尺寸、和HTML排版方式
@media screen and (min-resolution: 1.25dppx), /*通用像素密度*/
(min-device-pixel-ratio: 1.25),/*安卓ios使用谷歌火狐浏览器也可以使用*/
(min-resolution: 115dpi) /*万恶的IE*/
{
/*样式书写处*/
}
像素密度计算网站 http://dpi.lv网站
获取当前设备的像素密度 https://bjango.com/articles/min-device-pixel-ratio/ 或者使用 http://matanich.com/examples/pixel-density-tests/
示例DEMO / 同分辨率下不一样 dpi下处理
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<!--响应式网页 必备meta标签-->
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
.hh {
font-size: 16px;
background-color: rgb(255, 101, 101);
width: 500px;
}
/*像素密度计算网站 http://dpi.lv*/
/*获取当前设备的像素密度 https://bjango.com/articles/min-device-pixel-ratio/*/
@media screen and (min-resolution: 1.25dppx/*通用像素密度*/),(min-device-pixel-ratio: 1.25/*谷歌或安卓或ios使用*/),
(min-resolution: 115dpi/*万恶的IE*/)
{
.hh {
font-size: 30px;
background-color: rgb(255, 108, 108)
}
}
</style>
</head>
<body>
<p class="hh"> 这是测试文字</p>
</body>
</html>
真实示例
-
dpi放大倍率为1时效果
-
请注意下方网页UI字体大小 及柱状图下方文字菜单数量 以及 柱状图左侧Y轴数值
-
上方红线处是测试当前屏幕dpi 的放大倍数 (与windows 缩放与布局处一直 100%等于此处的 1 具体请参见:本章屏幕dpi是如何变化的呢?)
-
dpi放大倍率为1.25时效果
-
请注意下方网页UI字体大小 及柱状图下方文字菜单数量 以及 柱状图左侧Y轴数值
-
上方红线处是测试当前屏幕dpi 的放大倍数 (与windows 缩放与布局处一致 125%等于此处的 1.25 具体请参见:本章屏幕dpi是如何变化的呢?)