慣性聚合 関心のあるブログ、ニュース、テクノロジーを効率的に追跡
原文を読む 慣性聚合で開く

おすすめ購読元

雷峰网
雷峰网
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
The GitHub Blog
The GitHub Blog
博客园 - Franky
Google DeepMind News
Google DeepMind News
J
Java Code Geeks
Last Week in AI
Last Week in AI
V
Visual Studio Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
Blog — PlanetScale
Blog — PlanetScale
D
Docker
GbyAI
GbyAI
V
V2EX
IT之家
IT之家
酷 壳 – CoolShell
酷 壳 – CoolShell
博客园 - 聂微东
博客园_首页
月光博客
月光博客
量子位
罗磊的独立博客

DEV Community

Gemma 4 on Android: Tricks for Faster On-Device Inference Your AI agent has amnesia. You've just normalized it. I built an AI that reviews every PR automatically (because nobody was reviewing mine) 🌿 Git Mastery: The Complete Developer Guide Bringing Gemma 4 E2B to the Edge: Building a Privacy-First Dream Analyzer with Flutter & LiteRT Google I/O 2026 Wasn’t About Features — It Was About AI Becoming the Developer Environment Building an AI Vedic Astrology App in 25 Days — What Actually Worked (and What Didn't) Hermes Agent Has Four Memories — And That's Why It Doesn't Forget You Pressure Isn't Killing You -Your Relationship With It Is 🐳 How to Run Any Project in Docker: A Complete Guide AccessLens — a blind person's lanyard, powered by Gemma 4 on-device Glyph v0.2: the release is the joinery How I Built a Blazingly Fast, Privacy-First Batch Image Converter in the Browser Using OPFS and Web Workers Cómo solucionar \"Text content does not match server-rendered HTML\" en Next.js App Router FCoP 3.0: Why AI Agents Need a Track, Not a Brake Fibonacci: Quiz app which anyone can make revenue by viewing ads to the quiz contestants. The Subconscious Powered by Edge AI GPU Utilization Is Becoming the New Cloud Waste Crisis Cómo solucionar `docker run` con exit code 1 en Raspberry Pi JWT is a scam and your app doesn't need it 7 Agent Skill Packs That Actually Make AI Coders Better More Control, More Cost: Why Commanding AI Isn't Delegation SecureScan Synthadoc: We Built an AI Judge for Our AI Wiki Compiler - Here's What We Learned Cómo solucionar el error de permiso al ejecutar `pip.exe` en entorno virtual (Python 3.10 en Windows) Postgres-grade Serializable at 20k+ ops/s — on a laptop. Don’t try this at home. Pure Core, Imperative Shell in Rust with Stillwater Lean 4 for Programmers: Building a Todo List with Proof Trustless Bug Bounty Releases with a PoW-Gated DLC Oracle Building Autonomous DevOps Agents with MCP and LangChain Multimodal Gemma 4 Visual Regression & Patch Agent Git Time Machine — How Version Control Can Save Your Project My Dad Got an Electricity Bill He Couldn't Understand. Google I/O 2026 Just Made That Problem Solvable. My Dad Got an Electricity Bill He Couldn't Understand. Google I/O 2026 Just Made That Problem Solvable. Read Replicas Lie About Consistency. 4 Sync Modes Behind the Lie. Reviving My Coding Project with GitHub Copilot I Tried Gemini 3.5 Flash After Google I/O 2026 - Here is What I Found :)) Zero-Cost AI in VS Code Blueprints Might Be More Important Than Frameworks AI CareCompanion - Offline Health Assistant Long-Context Models Killed RAG. Except for the 6 Cases Where They Made It Worse. I Built a Neural Network Engine in C# That Runs in Your Browser - No ONNX Runtime, No JavaScript Bridge, No Native Binaries An In-Depth Overview of the Apache Iceberg 1.11.0 Release Your Agent Just Called the Same Tool 47 Times. Here's the 20-Line Detector. How I Built a Multi-System Astrology Bot in Python (And What Meta Banned Me For) Gemma 4 Has Four Variants. Here's How to Pick the Right One Before You Write a Single Line of Code. Log Level Strategies: Balancing Observability and Cost Why WebMCP Is the Most Important Thing Google Announced at I/O 2026 (And Nobody's Talking About It) Making LLM Calls Reliable: Retry, Semaphore, Cache, and Batch Google's 2x Energy Efficiency Claim Is Real — But Here's What They're Not Measuring
CSSにおける数学的関数:clamp、min、maxとそれらがレスポンシブデザインをどのように簡略化するか
Nick Benksim · 2026-05-23 · via DEV Community

Nick Benksim

レイアウトの悩みを解決する数学的な解決策

コーヒーを一杯飲んで、レスポンシブデザインについて本気で話し合いましょう。私たちは皆、あの状況にいることがあります:見事なレイアウトを作成し、27インチの5Kモニターで完璧にクリアに見えます。しかし、iPhone SEや巨大なウルトラワイドスクリーンでテストすると、デザインが完全に崩壊します。ヘッドラインは途方もないほど引き伸ばされ、またはマイクロスコープサイズのテキストに縮小されます。マージンが膨らみ、コンポーネントが最悪の方法で重なります。

すべてのデバイスでレイアウトが完璧に見えるようにするには、無限のメディアクエリを書く必要がありました。しかし、今はCSSの武器庫にスマートなツールがあり、重い仕事を私たちに代わってこなしてくれます:数学的関数clamp()min()、およびmax()です。それらがどのようにしてあなたの頭を救い、スタイルシートを整理してくれるかを見てみましょう。

私たちが苦しんでいた頃

レスポンシブウェブデザインの暗黒時代を覚えていますか?フォントをビューポートに合わせて動的にスケールさせるために、vwのようなビューポート単位に頼っていました。紙上では素晴らしく思われたのです:font-size: 5vwを設定するだけで、それがスケールするのを観察するだけ!しかし実際には、小さな画面では、あなたの5vwのテキストが読み取りにくい4pxに縮小し、巨大な画面では120pxの見出しになってしまいました。

この狂気を止めるために、私たちは2つの痛ましい回避策に頼らざるを得ませんでした

  • 一打を書く@media異なるブレークポイントでのルールを手動でフォントサイズとパディングを上書きする。
  • マジックミラーのように読み取りにくいCSSの式を使うようなcalc(16px + (24 - 16) * ((100vw - 320px) / (1200 - 320))).

あの式を見てPTSDになるなら、あなたは一人じゃない。それはメンテナンス不可能で、タイプミスに陥りやすく、ハックのように感じた。私たちは以前、CSS Subgridがグリッドのアライメントの問題を解決する前に、ネストされたレイアウトで苦労したのと同じように、レスポンシブなタイポグラフィとスペーシングの管理は非常に面倒だった。

2026年の現代の方法

今日、CSSの数学的な三つの柱—min()max()、およびclamp()は完全にサポートされており、非常に堅牢で、数百行のメディアクエリを置き換える準備ができています。簡単な言葉でどのように機能するか説明します:

1. max(value1, value2, ...)

max()関数は、与えた値を比較し、最も大きい値を選びます。それを設定するイメージに思い出してくださいプロパティの最小高さwidth: max(50%, 300px)です。例えば、__JHSNS_SEG_58d0e0da_33__は「画面の半分を占めるが、300px未満に縮小しない」と意味します

2. min(value1, value2, ...)

min()関数はその逆を行います:値を比較し、最小の値を選択します。これは最大上限として機能します の例として、width: min(80%, 1200px) は「画面の 80% を占めるが、1200px に達したらフリーズする」と意味します。

3. clamp(minimum, preferred, maximum)

これは現代のレスポンシブデザインの絶対的な聖杯です。clamp()3つの引数を取ります:下限、流体/推奨値、および上限。推奨値を厳密に最小値と最大値の範囲内に保持します。メディアクエリを一度も書かずに流体なタイポグラフィと動的なスペーシングを扱う最終手段です。

これらの数学的関数を最先端のレイアウトシステムと組み合わせるとCSSコンテナクエリ、完全流体でモジュラーでコンテキストに対応したコンポーネントを得られます.

すぐに使用できるコードスニペット

実際の現実世界の例を見てみましょう。ここには、CSSの数学関数を使用して、タイポグラフィ、内部パディング、全体的な幅を単一のブレークポイントルールなしで流体にスケールするクリーンでモダンなカードコンポーネントがあります.

/* A fully responsive, modern card layout */
.responsive-card {
  /* Dynamic width: takes up 90% of screen but caps at 600px */
  width: min(90%, 600px);
  
  /* Fluid padding: scales between 1rem and 2.5rem based on screen width */
  padding: clamp(1rem, 4vw, 2.5rem);
  
  background-color: #1e1e24;
  color: #f5f5f7;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
  margin: 2rem auto;
}

.card-title {
  /* Fluid typography: scales between 1.5rem and 3rem based on viewport */
  font-size: clamp(1.5rem, 5vw, 3rem);
  line-height: 1.2;
  margin-bottom: 1rem;
}

.card-text {
  /* Smart text sizing that scales but stays readable */
  font-size: clamp(1rem, 1rem + 1vw, 1.25rem);
  line-height: 1.6;
  opacity: 0.9;
}

初心者によくある間違い

CSSの数学関数は魔法のように見えるが、開発者はよく2つの古典的な落とし穴に陥る:

「静的な値」の落とし穴: clamp(1rem, 2rem, 3rem)のようなものを書くと。もし中間(好みの)値が静的であれば、関数は動的に計算するものがない!ブラウザは2rem それが決して変わらないことを確認し、単に要素を 2rem でロックします。中央の値は常に動的な単位(例えば vwvh、またはパーセンテージ)を含める必要があります。

アクセシビリティの落とし穴: 純粋なビューポート単位(例えば 5vw)を優先値として使用してclamp() でテキストを使用します。ユーザーがブラウザの設定でズームを入れると、ビューポート単位はズームに合わせてスケールされません。ウェブサイトをアクセシブルにし、WCAG ガイドラインに準拠するためには、常に数学関数内でビューポート単位と相対単位(remem のような)を組み合わせてください。clamp(1.2rem, 1rem + 2vw, 2.5rem) を記述することで、フォントが画面サイズに合わせて美しくスケールしながら、ユーザーのズーム設定を尊重することができます。

🔥 より高度なCSSのテクニック、すぐに使えるスニペット、およびチュートリアルを私たちのTelegramチャンネルで発行しています。購読して逃さないで!