CSS进阶之移动端适配 :媒体查询、CSS常见单位、深入理解pixel、DPR、PPI、浏览器视口Viewport、移动端适配rem方案、移动端适配vw方案

在移动端适配中,我们通常使用媒体查询和相关CSS单位来实现响应式布局。以下是一些关键点和示例代码:

  1. 媒体查询:



/* 针对不同屏幕宽度的样式 */
@media screen and (max-width: 320px) {
    body {
        background-color: blue;
    }
}
 
@media screen and (min-width: 321px) and (max-width: 768px) {
    body {
        background-color: green;
    }
}
 
@media screen and (min-width: 769px) {
    body {
        background-color: red;
    }
}
  1. CSS单位:

    • px:像素,是固定单位,不适应不同的设备。
    • em:相对于父元素的字体大小,容易造成层级复杂度。
    • rem:相对于根元素的字体大小,是现代响应式布局的首选单位。
    • %:百分比,相对于父元素,适合宽度设置。
    • vw/vh:视口宽度/高度的百分比,适合宽度和高度设置。
    • vmin/vmax:视口宽度和高度中较小/较大的那个百分比,适合图片和背景。
  2. 设备像素比(Device Pixel Ratio, DPR):

    • CSS中可以用1px等同于1dp(设备像素),在高分辨率设备上会出现问题。
    • 可以用window.devicePixelRatio获取DPR,进行适配。
  3. 像素密度(Pixels Per Inch, PPI):

    • 用于衡量屏幕的密度,可以通过window.screen.width / window.screen.height和屏幕物理尺寸结合使用。
  4. 视口(Viewport):

    • 为了使网站在移动端上正常显示,需要设置<meta name="viewport"标签。
    • 例如:<meta name="viewport" content="width=device-width, initial-scale=1.0">
  5. 使用calc()函数结合媒体查询进行布局调整:



.container {
    width: calc(100% - 20px); /* 计算宽度 */
    font-size: 16px; /* 默认字体大小 */
}
 
@media screen and (min-width: 321px) {
    .container {
        width: calc(100% - 25px); /* 根据屏幕宽度调整 */
        font-size: 18px; /* 增加字体大小 */
    }
}
 
@media screen and (min-width: 769px) {
    .container {
        width: calc(100% - 30px); /* 更大屏幕宽度调整 */
        font-size: 20px; /* 进一步增加字体大小 */
    }
}

综上,移动端适配主要是通过媒体查询、CSS单位、设备像素比和视口管理来实现不同屏幕大小的适配。通过这些技术,开发者可以创建出在各种移动设备上都能保持良好用户体验的网页。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日