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 相关文章推荐
CSS3样式linear-gradient的使用实例
Jan 16 HTML / CSS
css3中新增的样式使用示例附效果图
Aug 19 HTML / CSS
CSS3中的clip-path使用攻略
Aug 03 HTML / CSS
详解CSS3 Media Queries中媒体属性的使用
Feb 29 HTML / CSS
Grid 宫格常用布局的实现
Jan 10 HTML / CSS
自定义html标记替换html5新增元素
Oct 17 HTML / CSS
HTML5通过调用canvas对象的getContext()方法来获取绘图环境
Jun 23 HTML / CSS
HTML5 video 事件应用示例
Sep 11 HTML / CSS
有关HTML5中背景音乐的自动播放功能
Oct 16 HTML / CSS
HTML5拖拽文件上传的示例代码
Mar 04 HTML / CSS
详解使用 CSS prefers-* 规范提升网站的可访问性与健壮性
May 25 HTML / CSS
css3 选择器
May 11 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
use jscript Create a SQL Server database
2007/06/16 Javascript
jQuery解决iframe高度自适应代码
2009/12/20 Javascript
用AJAX返回HTML片段中的JavaScript脚本
2010/01/04 Javascript
JS高级笔记
2011/07/13 Javascript
用js格式化金额可设置保留的小数位数
2014/05/09 Javascript
使用jQuery实现WordPress中的Ctrl+Enter和@评论回复
2016/05/21 Javascript
jqGrid用法汇总(全经典)
2016/06/28 Javascript
AngularJS 服务详细讲解及示例代码
2016/08/17 Javascript
jQuery获取this当前对象子元素对象的方法
2016/11/29 Javascript
js实现增加数字显示的环形进度条效果
2017/02/05 Javascript
NodeJS配置HTTPS服务实例分享
2017/02/19 NodeJs
基于HTML5+JS实现本地图片裁剪并上传功能
2017/03/24 Javascript
vue.js实现刷新当前页面的方法教程
2017/07/05 Javascript
浅谈vue-lazyload实现的详细过程
2017/08/22 Javascript
微信小程序之GET请求的实例详解
2017/09/29 Javascript
基于webpack.config.js 参数详解
2018/03/20 Javascript
Vue注册组件命名时不能用大写的原因浅析
2019/04/25 Javascript
Layui数据表格 前后端json数据接收的方法
2019/09/19 Javascript
详解Angular cli配置过程记录
2019/11/07 Javascript
[01:27:44]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Aster BO3 第一场 1月24日
2021/03/11 DOTA
一篇文章快速了解Python的GIL
2018/01/12 Python
Django 拆分model和view的实现方法
2019/08/16 Python
Python使用socket模块实现简单tcp通信
2020/08/18 Python
selenium+headless chrome爬虫的实现示例
2021/01/08 Python
css 元素选择器的简单实例
2016/05/23 HTML / CSS
中级会计职业生涯规划范文
2014/01/16 职场文书
优秀教师获奖感言
2014/01/31 职场文书
售后服务经理岗位职责
2014/02/25 职场文书
献爱心捐款倡议书
2014/05/14 职场文书
外贸业务员求职信
2014/06/16 职场文书
临时工聘用合同协议书
2014/10/29 职场文书
傅雷家书读书笔记
2015/06/29 职场文书
Mysql数据库值的添加、修改、删除及清空操作实例
2021/06/20 MySQL
Python编程源码报错解决方法总结经验分享
2021/10/05 Python
关于Nginx中虚拟主机的一些冷门知识小结
2022/03/03 Servers
永中文档在线转换预览基于nginx配置部署方案
2022/06/10 Servers