当前位置: 首页 > article >正文

CSS 容器查询完全指南

CSS 容器查询完全指南引言CSS 容器查询Container Queries是 CSS 规范中的一项革命性特性它允许开发者根据容器的尺寸而非视口尺寸来应用样式。本文将深入探讨容器查询的各种用法和高级技巧。基础概念回顾容器查询 vs 媒体查询特性媒体查询容器查询基于视口尺寸容器尺寸语法mediacontainer作用范围全局局部基本语法container (min-width: 400px) { .card { flex-direction: row; } }高级技巧一容器类型size 容器.container { container-type: size; }inline-size 容器.container { container-type: inline-size; }block-size 容器.container { container-type: block-size; }高级技巧二命名容器定义命名容器.card-container { container-type: inline-size; container-name: card; }使用命名容器container card (min-width: 400px) { .card { flex-direction: row; } }组合使用container card (min-width: 400px) and (max-width: 600px) { .card { padding: 1.5rem; } }高级技巧三容器查询单位cqw - 容器查询宽度单位container (min-width: 400px) { .title { font-size: 5cqw; } }cqh - 容器查询高度单位container (min-height: 300px) { .content { font-size: 3cqh; } }cqi - 容器查询内联轴单位container (min-inline-size: 400px) { .item { width: 25cqi; } }cqb - 容器查询块轴单位container (min-block-size: 300px) { .item { height: 25cqb; } }cqmin 和 cqmaxcontainer (min-width: 400px) { .box { padding: cqmin(10px, 5%); } }高级技巧四嵌套容器查询基础嵌套.outer { container-type: inline-size; container-name: outer; } .inner { container-type: inline-size; container-name: inner; } container outer (min-width: 600px) { .card { background: blue; } container inner (min-width: 300px) { .title { font-size: 1.5rem; } } }多层嵌套.level-1 { container-type: inline-size; container-name: level1; } .level-2 { container-type: inline-size; container-name: level2; } .level-3 { container-type: inline-size; container-name: level3; } container level1 (min-width: 800px) { container level2 (min-width: 600px) { container level3 (min-width: 400px) { .content { color: red; } } } }高级技巧五容器查询与 Flexbox/Grid响应式 Flexbox.card-container { container-type: inline-size; container-name: cardContainer; display: flex; gap: 1rem; } container cardContainer (max-width: 500px) { .card-container { flex-direction: column; } }响应式 Grid.grid-container { container-type: inline-size; container-name: gridContainer; display: grid; grid-template-columns: repeat(4, 1fr); } container gridContainer (max-width: 800px) { .grid-container { grid-template-columns: repeat(2, 1fr); } } container gridContainer (max-width: 400px) { .grid-container { grid-template-columns: 1fr; } }实战案例响应式卡片组件.card { container-type: inline-size; container-name: card; padding: 1rem; border-radius: 8px; background: white; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); } .card-header { margin-bottom: 1rem; } .card-title { font-size: 1rem; font-weight: bold; } .card-content { font-size: 0.875rem; color: #666; } .card-actions { margin-top: 1rem; display: flex; gap: 0.5rem; } container card (min-width: 300px) { .card { padding: 1.5rem; } .card-title { font-size: 1.25rem; } .card-content { font-size: 1rem; } } container card (min-width: 400px) { .card { display: flex; gap: 1.5rem; } .card-header { flex-shrink: 0; width: 150px; } .card-body { flex: 1; display: flex; flex-direction: column; justify-content: space-between; } .card-actions { justify-content: flex-end; } }实战案例响应式导航栏.navbar { container-type: inline-size; container-name: navbar; display: flex; align-items: center; justify-content: space-between; padding: 1rem; background: #333; color: white; } .logo { font-size: 1.25rem; font-weight: bold; } .nav-links { display: none; gap: 1.5rem; } .nav-links a { color: white; text-decoration: none; } .mobile-menu { display: block; cursor: pointer; } container navbar (min-width: 600px) { .nav-links { display: flex; } .mobile-menu { display: none; } }实战案例响应式表单.form-container { container-type: inline-size; container-name: formContainer; padding: 1rem; } .form-group { margin-bottom: 1rem; } .form-group label { display: block; margin-bottom: 0.5rem; font-weight: 500; } .form-group input, .form-group textarea { width: 100%; padding: 0.75rem; border: 1px solid #ddd; border-radius: 4px; } .form-actions { display: flex; gap: 0.5rem; } container formContainer (min-width: 500px) { .form-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; } .form-actions { justify-content: flex-end; } } container formContainer (min-width: 700px) { .form-row { grid-template-columns: repeat(3, 1fr); } }常见问题与解决方案Q1浏览器兼容性如何A现代浏览器都支持容器查询Chrome 105Firefox 110Safari 16Edge 105Q2如何优雅降级A使用 supports 检测.card { padding: 1rem; } supports (container-type: inline-size) { .card { container-type: inline-size; } container (min-width: 400px) { .card { padding: 1.5rem; } } }Q3容器查询与媒体查询冲突吗A不冲突可以结合使用media (min-width: 1024px) { .container { display: flex; gap: 2rem; } } container (min-width: 400px) { .card { flex-direction: row; } }最佳实践1. 使用 inline-size 优先/* 推荐 */ .container { container-type: inline-size; } /* 不推荐 */ .container { container-type: size; }2. 命名容器/* 推荐 */ .card-container { container-type: inline-size; container-name: card; } container card (min-width: 400px) { /* 样式 */ } /* 不推荐 */ .card-container { container-type: inline-size; } container (min-width: 400px) { /* 样式 */ }3. 结合 CSS Grid.grid { container-type: inline-size; container-name: grid; display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); } container grid (min-width: 600px) { .grid { grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); } }总结CSS 容器查询是响应式设计的重大进步。通过本文的学习你应该能够理解容器查询的概念和优势使用不同类型的容器查询应用容器查询单位实现嵌套容器查询构建响应式组件掌握这些技巧能够帮助你创建更加灵活和可复用的组件。

相关文章:

CSS 容器查询完全指南

CSS 容器查询完全指南 引言 CSS 容器查询(Container Queries)是 CSS 规范中的一项革命性特性,它允许开发者根据容器的尺寸而非视口尺寸来应用样式。本文将深入探讨容器查询的各种用法和高级技巧。 基础概念回顾 容器查询 vs 媒体查询 特…...

Flutter Provider 状态管理完全指南

Flutter Provider 状态管理完全指南 引言 Provider 是 Flutter 中最流行的状态管理方案之一,它基于 InheritedWidget 实现,提供了简单而强大的状态管理方式。本文将深入探讨 Provider 的各种用法和高级技巧。 基础概念回顾 Provider 类型 Provider - 最基…...

CSS 混合模式完全指南

CSS 混合模式完全指南 引言 CSS 混合模式(Blend Modes)是一种强大的视觉效果工具,它允许你控制多个元素或图层如何混合在一起。本文将深入探讨各种混合模式的用法和高级技巧。 混合模式类型 基础混合模式 模式效果描述normal默认模式&#xf…...

C++ 知识点22 函数模板

C 函数模板一、为什么要有函数模板?先看痛点:你要写两个交换函数,int 版、double 版:// int 交换 void swapInt(int &a, int &b) {int t a; a b; b t; } // double 交换 void swapDouble(double &a, double &b…...

Flutter 自定义动画完全指南

Flutter 自定义动画完全指南 引言 动画是现代移动应用的重要组成部分,它能够提升用户体验,使界面更加生动。Flutter 提供了强大的动画系统,本文将深入探讨如何创建自定义动画效果。 动画基础回顾 动画类型 补间动画 (Tween Animation) - 最常…...

cpdown:精准下载Git仓库文件,告别克隆整个项目的低效操作

1. 项目概述与核心价值最近在整理本地开发环境,发现一个高频痛点:从各种代码托管平台(比如 GitHub、GitLab、Gitee)下载单个文件或特定目录时,总是特别麻烦。要么得克隆整个仓库,动辄几百兆,浪费…...

基于浏览器自动化的高级爬虫框架autoclaw实战指南

1. 项目概述与核心价值最近在折腾自动化脚本时,发现了一个挺有意思的GitHub项目,叫jmoraispk/autoclaw。乍一看名字,可能会联想到“自动爪子”或者“爬虫”,实际上,它也确实是一个专注于自动化网页交互和数据抓取的工具…...

别再为Modbus RTU超时头疼了!STM32CubeMX+FreeModbus从站移植,搞定串口与定时器配置的黄金法则

STM32CubeMXFreeModbus从站移植实战:破解RTU超时难题的工程化思维 当你在深夜调试Modbus RTU从站设备,串口调试助手反复弹出"Timeout"错误提示时,那种挫败感每个嵌入式工程师都深有体会。超时问题就像幽灵般难以捉摸——代码编译通…...

别再傻傻分不清!Ansys Workbench三大建模界面(SCDM/DM/Mechanical)保姆级对比与选用指南

Ansys Workbench三大建模界面深度解析:如何根据项目需求选择最佳工具 在工程仿真领域,Ansys Workbench作为行业标杆软件套件,其内置的三大建模界面——SpaceClaim(SCDM)、DesignModeler(DM)和Me…...

AD7606模块的20kHz高速采样怎么玩?深入对比带缓存与不带缓存的两种采集模式

AD7606模块20kHz高速采样的工程实践:带缓存与无缓存模式深度解析 在工业自动化、电力监测和振动分析等领域,多通道高速数据采集系统常面临一个关键抉择:如何在有限的处理器资源下实现最优的采样性能?AD7606作为一款经典的八通道16…...

别再只盯着原理图了!用Python+OpenCV动手模拟激光三角测距(斜射/直射对比)

用PythonOpenCV模拟激光三角测距:斜射与直射的实战对比 激光三角测距技术听起来高大上,但真正理解它的精髓往往需要跳出公式推导的泥潭。作为一名长期在工业检测领域摸爬滚打的技术人员,我发现用代码模拟物理过程是最有效的学习方式。本文将…...

从原理到实战:使用Kali Linux进行WiFi安全渗透测试

1. WiFi安全渗透测试基础 很多人可能觉得WiFi密码破解是个神秘的黑客技术,其实它只是网络安全领域中一个基础的安全测试手段。作为一名安全研究员,我经常需要在获得授权的情况下,对客户的无线网络进行安全评估。Kali Linux作为专业的渗透测试…...

别再到处找激活码了!手把手教你用vlmcsd在Windows上自建KMS服务器(附各版本密钥)

企业级Windows批量激活解决方案:安全高效的本地KMS部署指南 在数字化办公环境中,批量激活Windows操作系统一直是IT管理员面临的常见挑战。传统单机激活方式效率低下,而依赖外部KMS服务器又存在连接不稳定、隐私泄露等潜在风险。本文将深入探讨…...

终极ROFL播放器指南:如何免费快速解锁英雄联盟回放文件分析

终极ROFL播放器指南:如何免费快速解锁英雄联盟回放文件分析 【免费下载链接】ROFL-Player (No longer supported) One stop shop utility for viewing League of Legends replays! 项目地址: https://gitcode.com/gh_mirrors/ro/ROFL-Player 还在为无法查看英…...

从仿真到论文图表:手把手教你用FDTD参数扫描和Matlab处理WO3薄膜光学数据

从仿真到论文图表:FDTD参数扫描与Matlab数据可视化全流程解析 在光电材料研究中,WO₃薄膜因其优异的电致变色特性备受关注。当我们需要系统研究薄膜厚度对光学性能的影响时,FDTD Solutions的参数扫描功能配合Matlab的数据处理能力&#xff0c…...

鸿蒙数据持久化三板斧:Preferences、RDB、分布式数据一文搞定,告别数据丢失

📖 鸿蒙NEXT开发实战系列 | 第21篇 | 数据篇 🎯 适合人群:有鸿蒙基础的开发者 ⏰ 阅读时间:约15分钟 | 💻 开发环境:DevEco Studio 5.0 ⬅️ 上一篇:20-网络篇-网络请求与数据加载 ➡️ 下一篇&…...

STM32CubeMX LL库配置外部中断,从按键消抖到中断嵌套的实战避坑指南

STM32CubeMX LL库外部中断深度优化:从硬件消抖到中断嵌套的工程实践 当你的嵌入式系统需要实时响应外部事件时,外部中断(EXTI)往往是最高效的选择。但在实际项目中,简单配置EXTI只是开始——按键抖动导致的误触发、中断优先级冲突引发的死锁、…...

SAP资产会计进阶:深入理解AS91、AB01与ABLDT在期初数据处理中的角色与联动

SAP资产会计核心事务代码解析:AS91、AB01与ABLDT的协同逻辑与实战应用 在SAP S4 HANA资产模块的实施与运维中,期初数据处理往往是项目成败的关键节点。不同于日常资产操作,期初数据迁移涉及历史价值追溯、折旧逻辑重建以及多系统数据对齐等复…...

别再死记硬背了!用Python+Graphviz把离散数学的图论和关系画出来(附代码)

用PythonGraphviz将离散数学中的抽象概念可视化 离散数学是计算机科学的基础课程之一,但其中的图论、二元关系等概念往往因为高度抽象而让学习者感到困惑。传统的死记硬背方式不仅效率低下,也难以真正理解这些概念的本质。本文将介绍如何利用Python的net…...

从配置字到实际运动:手把手教你用EtherCAT调试伺服电机的控制模式(以倍福TwinCAT3为例)

从配置字到实际运动:手把手教你用EtherCAT调试伺服电机的控制模式(以倍福TwinCAT3为例) 在工业自动化现场,伺服电机的精准控制往往决定着整条产线的运行效率。当面对一台全新的伺服驱动器时,如何快速完成从参数配置到实…...

从日偏食图像处理开始:手把手在VS2019里跑通你的第一个OpenCV 4.3程序

从日偏食图像处理开始:手把手在VS2019里跑通你的第一个OpenCV 4.3程序 当那张日偏食照片第一次在屏幕上成功显示时,仿佛打开了计算机视觉的大门。本文将带你从零开始,用VS2019和OpenCV 4.3实现这个充满仪式感的"Hello World"——不…...

从CMake报错到编译成功:一站式解决absl依赖配置难题

1. 当CMake突然报错:absl依赖缺失的紧急处理 第一次看到这个报错时,我正赶着在截止日期前完成gRPC服务的部署。控制台突然弹出的红色错误让我心头一紧:"Could not find a package configuration file provided by absl"。这种依赖缺…...

【PyTorch实战】从零构建Prototypical Network:小样本图像分类的度量学习核心

1. 小样本学习与Prototypical Network基础 当你第一次听说"小样本学习"时,可能会觉得这是个遥不可及的高深概念。其实它的核心思想很简单:就像人类能通过少量例子快速学习新事物一样,让AI模型也具备这种能力。想象一下,…...

技术Leader的困境:为什么你越努力,团队越依赖你?

在软件测试领域,我们比任何角色都更懂“依赖”这个词。测试环境依赖稳定、测试数据依赖真实、测试用例依赖需求文档。但有一种依赖,最致命却也最容易被忽视——团队对你的依赖。很多从一线测试骨干晋升为测试Leader的人,都会陷入一个怪圈&…...

工程实践:AI 编程从提示词走向流水线,才需要 API 中转站

这类内容的核心判断应该换一下:用户不是先想买 API,中间才想到 Claude / Codex;很多时候正相反,是先想用 Claude / Codex 提升开发效率,才开始寻找稳定、可接入、可支付、可迁移的 API 入口。目标用户画像想把需求分析…...

HBase集群启动后秒退?手把手教你排查ZooKeeper路径配置与htrace-core缺失问题

HBase集群启动后秒退?深度排查ZooKeeper路径与依赖缺失问题 当你在深夜部署HBase集群时,看到服务启动后几秒钟内突然消失,那种感觉就像在黑暗中摸索开关。这不是简单的配置错误,而是系统在向你发出求救信号。让我们像侦探一样&…...

机器学习之随机森林详解

摘要随机森林(Random Forest)是一种基于Bagging集成学习思想的 ensemble method,通过构建多棵决策树并综合其预测结果来实现分类和回归任务。本文详细介绍了随机森林的核心原理、关键超参数、OOB误差估计机制,以及其在特征重要性分…...

终极Mac菜单栏整理指南:用Ice让你的桌面从此清爽高效

终极Mac菜单栏整理指南:用Ice让你的桌面从此清爽高效 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice 你是否厌倦了Mac菜单栏上密密麻麻的图标?是否经常因为找不到需要的应用图…...

Linux桌面便签终极方案:Sticky让你的灵感永不丢失

Linux桌面便签终极方案:Sticky让你的灵感永不丢失 【免费下载链接】sticky A sticky notes app for the linux desktop 项目地址: https://gitcode.com/gh_mirrors/stic/sticky 在Linux桌面上高效管理零散信息一直是许多用户的痛点。Sticky作为一款专为Linux…...

绝地求生罗技鼠标宏实战指南:5步实现高效压枪技巧

绝地求生罗技鼠标宏实战指南:5步实现高效压枪技巧 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 对于《绝地求生》玩家来说&#xf…...