您现在的位置是:网站首页> 编程资料编程资料
CSS像素以及移动端不同屏幕适配问题解决css列表滑动防止被底部遮住和适配屏幕长一点的机型处理 CSS3中媒体查询结合rem布局适配手机屏幕
2021-09-03
860人已围观
简介 这篇文章主要介绍了CSS像素以及移动端不同屏幕适配问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
像素
分辨率
我们通常所说的显示器分辨率,其实是指桌面设定的分辨率,而不是显示器的物理分辨率。只不过现在液晶显示器成为主流,由于液晶的显示原理与CRT不同,只有在桌面分辨率与物理分辨率一致的情况下,显示效果最佳,所以现在我们的桌面分辨率几乎总是与显示器的物理分辨率一致了。
UI稿的像素
UI稿的像素是指物理像素
我们接到的UI设计稿例如750px就是物理像素
前端像素
只要两个屏幕逻辑像素相同,它们的显示效果就是相同的。 也就是CSS世界中的px相同,相同物理尺寸的屏幕显示效果就是相同的
那么在实际屏幕显示的时候他们之间都有神马关系呢?
如下图 当我们在网页上设置一个元素的css像素(width:2px;height:2px)时,在dpr=1的显示器上时,最终会占用一个四个物理像素点,当在dpr=2时的显示器上时,会占用16个物理像素点。由此得出结论,在不同屏幕下css像素的物理尺寸是一致的,不同的是一个css像素对应的物理像素点个数不一样

不同屏幕下的rem适配方案
// 适配 物理像素宽750 1rem=100px // clientWidth(实际的逻辑像素)/375(参照基准逻辑像素) = fontSize(实际的1rem像素值)/100(参照的1rem逻辑像素值) ;(function(win, doc){ function change(){ doc.documentElement.style.fontSize=100*doc.documentElement.clientWidth/375+'px'; } change(); win.addEventListener('resize', change, false); })(window, document); // 这样我们就计算出实际不同逻辑像素下1rem的值了 // 实际工作中如果UI给是设计稿宽度是750px 那么我们就需要在量到的宽度的基础上除以200 // 我们在打开控制台查看元素之间的距离的时候都是设计稿上的一半 设计稿的物理像素2px对应逻辑像素1px // 我司现在的设计稿都放在蓝湖上 宽度都是标准的375 那么我们只需要在量得的宽度基础上除以100就得到实际的宽度是多少rem // 附: 当然也有其他适配方案,但是rem原理都是一样的,除非采用的不是rem方案为什么苹果手机上需要2倍图或者三倍图?
以2倍屏为例

原本2*2像素的图片在2倍屏下 有4*4个像素点组成 那么多出来需要绘制的像素点的就会在以前周周附近找相似的,所以有了模糊的问题。现在工作中一般为了图片高清显示,都是采用苹果两倍图。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- css实现悬浮客服效果css做个波浪悬浮球的实现方法css3实现的多种3d纸张鼠标悬浮特效源码
- Grid 宫格常用布局的实现解析CSS中的Grid布局完全指南10分钟理解CSS3 Grid布局css中grid属性的使用详解CSS Grid 网格布局全解析CSS Grid布局教程之网格单元格布局CSS Grid布局教程之浏览器开启CSS Grid Layout汇总CSS Grid布局教程之什么是网格布局使用CSS Grid布局实现网格的流动
- CSS实现粒子动态按钮效果基于CSS3实现的复选框和单选按钮美化的动态特效CSS3实现的各种形状的3D立体按钮鼠标滑过带有动态效果纯CSS3制作的超酷动态变色立体按钮效果基于CSS3的 漂亮的动态按钮代码
- CSS3 旋转立方体问题详解CSS3过渡旋转透视2d3d动画等效果的实例代码CSS3只让背景图片旋转180度的实现示例CSS3 菱形拼图实现只旋转div 背景图片不旋转功能
- 解决Img图片底部空白缝隙问题CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- flex布局兼容性问题小结详解flex布局的元素如何分配容器的剩余空间flex布局被子元素撑开如何保持内容不超出容器的方法flex布局实现左侧文字溢出省略右侧文字自适应10分钟理解CSS3 FlexBox弹性布局详解flex实现左右布局中按钮溢出隐藏效果CSS3 Flex 弹性布局实例代码详解移动端优先的flex三栏布局的使用方法Flexbox 布局的最简单表单的实现css flex几种多列布局详解纯css实现瀑布流(multi-column多列及flex布局)
- css 元素显示隐藏的9种思路使用CSS隐藏元素滚动条的示例代码CATIA装配体中的所有参考元素怎么隐藏?CSS隐藏页面元素的5种方法CSS“隐藏”元素的多种方法的对比隐藏 Web 中的元素方法及优缺点教程详解
- css实现可控虚线的方法CSS border虚线边框属性教程DIV+CSS实例虚线边框|CSS虚线下划线及虚线用应css 网页虚线制作方法剖析纯CSS搞定按钮、链接点击时的虚线css 去除连接时的虚线框
- CSS动画实现背景无缝无限循环的实现示例用CSS3实现无限循环的无缝滚动的示例代码 用CSS3实现无限循环的无缝滚动的实例代码
- 使用Rem布局实现自适应浅谈移动端的自适应布局问题(响应式、rem/em、Js动态)
