css3媒体查询中device-width和width的区别详解


Posted in HTML / CSS onMarch 27, 2020

1.device-width

定义:定义输出设备的屏幕可见宽度。

不管你的网页是在safari打开还是嵌在某个webview中,device-width都只跟你的设备有关,如果是同一个设备,那么他的值就不会变。

比如iphone6的device-width*device-height为375*667,而跟他的dpr等无关。

2.width

定义:定义输出设备中的页面可见区域宽度。

输出的是你的网页可见区域的宽高,假设你的网页是移动端网页嵌套在某个webview中,width实际上就是webview的宽高,如果在不同的浏览器中,width和height也有可能不一样,又假如,你的页面用的rem布局,并且对于retina屏来说dpr>1,meta标签中设置了content="width=device-width, initial-scale=0.5, minimum-scale=0.5, maximum-scale=0.5, user-scalable=no,viewport-fit=cover",你的iphone6上的width大小就为750px了。

我这里用得比较用得多的是device-width和device-height,因为不用考虑横屏的情况

比如说适配iphoneX,你已经明确知道了iphoneX(375*812)的尺寸就可以用下面语句:

/*iphone x*/
@media only screen and (device-width:375px) and (device-height:812px) and (-webkit-device-pixel-ratio:3) {
    .foriphoneX()
}

又比如最新的三星折叠屏

@media screen and (device-width: 586px) and (device-height: 820px){
    html{
        font-size: 110px !important;
    }
}

总之,device-width在一个设备中是不会变的,他的值跟设备宽度有关,width在不同的布局方案或者不同的容器中展示都有可能不一样,这里我觉得device-width就相当于js的window.screen.width,width相当于js的document.body.clientWidth了。

另外记录一下我这里适配华为折叠屏的情况,由于此时还没真机,我只知道华为展开情况下的分辨率为2200*2480,dpr什么的还不清楚,因此不知道device-width和device-height(我这边不能用width来做查询,原因关系到业务逻辑),因此选了device-aspect-ratio,

最开始我在我的less中是这样写的

@media (device-aspect-ratio: 55/62) {
    /*适配*/
}

然后css中device-aspect-ratio被计算成小数了

@media (device-aspect-ratio: 0.887097) {
    /*适配*/
}

device-aspect-ratio是不支持小数的,因此匹配不上

所以查了一下怎么让less不执行55/62的结果,发现将属性用引号包起来,并且前面加上波浪号就可以了,像这样:

@media (device-aspect-ratio: ~"55/62") {
    /*适配部分*/
}

问题解决!

不过MDN上已经不推荐使用device-aspect-ratio了,这个属性将会被逐废弃,如果找到了更好的解决方案我也会用替代方案。

到此这篇关于css3媒体查询中device-width和width的区别详解的文章就介绍到这了,更多相关css3 device-width width内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
使用Filters滤镜弥补CSS3的跨浏览器问题以及兼容低版本IE
Jan 23 HTML / CSS
常用的四种CSS透明属性介绍
Apr 12 HTML / CSS
目前不被任何主流浏览器支持的CSS3属性汇总
Jul 21 HTML / CSS
CSS3 display知识详解
Nov 25 HTML / CSS
解决CSS3的opacity属性带来的层叠顺序问题
May 09 HTML / CSS
深入浅析CSS3中的Flex布局整理
Apr 27 HTML / CSS
html5使用canvas实现图片下载功能的示例代码
Aug 26 HTML / CSS
用html5的canvas和JavaScript创建一个绘图程序的简单实例
Jul 06 HTML / CSS
iPhoneX安全区域(Safe Area)底部小黑条在微信小程序和H5的屏幕适配
Apr 08 HTML / CSS
Html5+CSS3+EL表达式问题小结
Dec 19 HTML / CSS
ivx平台开发之不用代码实现一个九宫格抽奖功能
Jan 27 HTML / CSS
HTML5基础学习之文本标签控制
Mar 25 HTML / CSS
css3 flex实现div内容水平垂直居中的几种方法
Mar 27 #HTML / CSS
浅析CSS3 中的 transition,transform,translate之间区别和作用
Mar 26 #HTML / CSS
css3 中translate和transition的使用方法
Mar 26 #HTML / CSS
CSS3 不定高宽垂直水平居中的几种方式
Mar 26 #HTML / CSS
使用 CSS3 中@media 实现网页自适应的示例代码
Mar 24 #HTML / CSS
css3通过scale()、rotate()实现放大、旋转
Mar 19 #HTML / CSS
CSS3属性 line-clamp控制文本行数的使用
Mar 19 #HTML / CSS
You might like
PHP 的ArrayAccess接口 像数组一样来访问你的PHP对象
2010/10/12 PHP
PHP中英混合字符串截取函数代码
2011/07/17 PHP
解析link_mysql的php版
2013/06/30 PHP
php解析html类库simple_html_dom(详细介绍)
2013/07/05 PHP
php判断文件夹是否存在不存在则创建
2015/04/09 PHP
PHP超全局数组(Superglobals)介绍
2015/07/01 PHP
PHP+MySQL实现消息队列的方法分析
2018/05/09 PHP
几款极品的javascript压缩混淆工具
2007/05/16 Javascript
jQuery UI Dialog 创建友好的弹出对话框实现代码
2012/04/12 Javascript
javascript面向对象快速入门实例
2015/01/13 Javascript
javascript实现状态栏中文字动态显示的方法
2015/10/20 Javascript
js纯数字逐一停止显示效果的实现代码
2016/03/16 Javascript
jQuery实现选项卡功能(两种方法)
2017/03/08 Javascript
JS中SetTimeout和SetInterval使用初探
2017/03/23 Javascript
详解vue 兼容IE报错解决方案
2018/12/29 Javascript
ElementUI多个子组件表单的校验管理实现
2019/11/07 Javascript
浅谈JavaScript节流和防抖函数
2020/08/25 Javascript
JS中队列和双端队列实现及应用详解
2020/09/29 Javascript
python聊天程序实例代码分享
2013/11/18 Python
Python的Flask站点中集成xhEditor文本编辑器的教程
2016/06/13 Python
Python在groupby分组后提取指定位置记录方法
2018/04/20 Python
python自动登录12306并自动点击验证码完成登录的实现源代码
2018/04/25 Python
对Python中type打开文件的方式介绍
2018/04/28 Python
python逆序打印各位数字的方法
2018/06/25 Python
如何用C代码给Python写扩展库(Cython)
2019/05/17 Python
PyQt4编程之让状态栏显示信息的方法
2019/06/18 Python
如何通过Python实现RabbitMQ延迟队列
2020/11/28 Python
Pycharm在指定目录下生成文件和删除文件的实现
2020/12/28 Python
自主招生自荐书
2013/11/29 职场文书
三年大学自我鉴定
2014/01/16 职场文书
庆元旦迎新年广播稿
2014/02/18 职场文书
中职生求职信
2014/07/01 职场文书
警察正风肃纪剖析材料
2014/10/16 职场文书
初中信息技术教学反思
2016/02/16 职场文书
JavaScript控制台的更多功能
2021/04/28 Javascript
解决pycharm安装scrapy DLL load failed:找不到指定的程序的问题
2021/06/08 Python