• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 浅谈css3 device-width和width之间的差异

浅谈css3 device-width和width之间的差异

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了css3,device-width,width之间的差异等相关知识,希望对您有所帮助

本篇文章和大家谈谈css媒体查询中device-width与width的区别。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。


浅谈css3 device-width和width之间的差异


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了,这个属性将会被逐废弃,如果找到了更好的解决方案我也会用替代方案。


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • CSS3如何实现图片木桶布局?(附代码)
  • CSS3怎么实现卡片翻转效果
  • 纯CSS3怎么创建瀑布流布局?columns方法浅析
  • 用CSS3美化半个字符巧妙方法
  • CSS3背景图片固定滑动效果
  • CSS3实现文字折纸效果的方法(代码示例)
  • 小程序swiper轮播CSS3动画及跳转到指定swiper-item的使用
  • 超酷的CSS3 loading预加载动画特效
  • 浅谈css3 device-width和width之间的差异
  • CSS3怎么实现动画结束不消失效果

相关文章

  • 2022-04-29浅析什么是装饰器?Vue中怎么使用装饰器?
  • 2022-04-29一文详解Laravel如何安装inertia vue3的版本
  • 2022-04-29Vue3.0 新特性以及使用总结
  • 2022-04-29Wordpress Ripro美化版演示导入说明
  • 2022-04-29WordPress多站点不支持timthumb.php解决方法
  • 2022-04-29关于蓝奏网盘部分地区无法下载解决方案
  • 2022-04-29支付宝企业账户转账个人账户PHP接口代码
  • 2022-04-29PS制作质感的立体字
  • 2022-04-29Photoshop制作折纸风格的短信软件图标
  • 2022-04-29Photoshop简单制作蓝色洁净星星文字效果

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • PHPCMS V9后台复制指定文章到同模型的指定栏目中
    • PetalBot-华为自研搜索引擎,这个蜘蛛就是花瓣蜘蛛,将来或许也会在国内再杀出一个搜索引擎
    • 实例讲解Laravel队列的简单使用
    • Node.js深入学习之浅析require函数中怎么添加钩子
    • 介绍JavaScript正则实现表达式以字母开头
    • DEDECMS让广告延时加载,提高网页打开速度
    • Angular CLI发布路径的配置项浅析
    • 在非Laravel项目中怎么使用Validator验证器
    • 解决Ajax方式上传文件报错"Uncaught TypeError: Illegal invocation"
    • 动态获取织梦CMS最新更新 利于收录的SiteMap.php文

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有