Heim  >  Artikel  >  Web-Frontend  >  Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

青灯夜游
青灯夜游nach vorne
2021-01-27 19:23:032001Durchsuche

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

Manchmal brauche ich eine einfache Möglichkeit, ein Rasterlayout zu erstellen. Zeichnen Sie beispielsweise schnell ein fünfspaltiges Raster, ohne jedes Mal, wenn ich meine Meinung ändere, das CSS zu ändern. In diesem Artikel untersuchen wir einige Anwendungsfälle und überlegen, wie wir sie implementieren und nutzen können.

Wie es funktioniert

Bevor wir uns mit diesen Konzepten befassen, werfen wir zunächst einen Blick auf die Grundlagen von CSS-Variablen, die wir auch „benutzerdefinierte Eigenschaften“ nennen können.

Alle gängigen Browser unterstützen CSS-Variablen:

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

Wenn Sie eine CSS-Variable als globale Variable definieren möchten, müssen Sie sie zu :root-Deklaration (<code>:root entspricht ). Wenn die Variable komponentenspezifisch ist, kann sie in einer Deklaration innerhalb der Gruppe definiert werden. :root声明中(:root等效于)。 如果该变量特定于组件,则可以在该组内声明中定义它。

在下面的例子中,我定义了一个全局变量--size,它用于square 元素的宽度和高度。

:root {
    --size: 50px;
}

.square {
    width: var(--size);
    height: var(--size);
}

如果--size没有定义,要怎么办呢?在传递的变量无效的情况下,CSS 支持定义默认变量或回退变量。

在下面的例子中的 var(--size, 10px)。如果--size无效,则宽度和高度值将为 10px

.square {
    width: var(--size, 10px);
    height: var(--size, 10px);
}

除此之外,还可以在内联CSS样式中使用CSS变量。例如

HTML

<div class="elem" style="--background: red;"></div>

CSS

.elem {
    background: var(--background);
}

接着, 我们以上述这些概念,还演示一些事例。

CSS网格示例

侧边栏和主内容

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

在此设计中,我将CSS网格用于以下各项:

  1. 边栏和主菜单
  2. 表单项
  3. 三列布局

侧边栏的宽度是固定的,主内容是变化。假设侧边栏的宽度是240px

1.边栏和主菜单

Html

<div class="o-grid" style="--columns: 240px 1fr">
    <aside></aside>
    <main></main>
</div>

Html

.o-grid {
    display: grid;
    grid-template-columns: var(--columns);
}

2. 表单项

按照设计,每行有两列,html 结构如下:

Html

<div class="o-grid" style="--columns: 1fr 1fr">
  <div class="form-group"></div>
  <div class="form-group"></div>
  <div class="form-group"></div>
  <div class="form-group"></div>
</div>

CSS

.o-grid {
    display: grid;    
    grid-template-columns: var(--columns);
}

3. 三列布局

在下面的示例中,我添加了--repeat-number:3--gap:8px作为内联CSS。 这些变量将添加到o-grid类,网格的设置将基于这些变量。

HTML

<div class="o-grid" style="--repeat-number: 3; --gap: 8px;">
  <div></div>
  <div></div>
  <div></div>
</div>

CSS

.o-grid {
  display: grid;
  grid-template-columns: repeat(var(--repeat-number), 1fr);
  grid-gap: var(--gap, 0);
}

我喜欢在CSS变量中添加默认值,以防变量没有被设置。在上面的代码中,我使用了var(--gap, 0),如果使用者没有提供--gap变量,则其默认值将为0

动态网格项:minmax

对我来说,这是一个广泛使用的用例,并且非常重要。我经常使用Grid minmax,但是当我在多个页面上使用它时,我遇到了一个问题。

让我们举一个不使用 CSS 变量的基本示例。

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

在 CSS 中,我使用minmax为每个网格项目定义最小宽度250px

CSS

.o-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr);
  grid-gap: 16px;
}

现在,如果设计要求网格项目的宽度至少为300px,应该怎么做? 我需要创建类似以下版本吗?

.o-grid--2 {
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
}

想象一下,有五个不同的网格,每个网格具有不同的项目宽度,所以以上不是正确的解决方案。

使用CSS变量,我可以执行以下操作

.o-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--item-width), 1fr);
    grid-gap: var(--gap);
}

在HTML中,就可以在标签上设置 CSS 变量:

<!-- Example 1 -->
<div class="o-grid" style="--item-width: 250px;">
     <div></div>
     <div></div>
     <div></div>
</div>

<!-- Example 2 -->
<div class="o-grid" style="--item-width: 350px;">
     <div></div>
     <div></div>
     <div></div>
</div>

<!-- Example 3 -->
<div class="o-grid" style="--item-width: 150px;">
     <div></div>
     <div></div>
     <div></div>
</div>

事例源码:https://codepen.io/shadeed/pen/7d3e0d575a5cecb86233fc7d72fa90d4

Flexbox示例

在示例中,有一个文章标题,其中包含作者姓名和标签。 这些在页面中的排布方式是动态变化,所以需要一种快速切换这些布局方式的方法 。

HTML

<div class="article-header">
    <h2>Article title</h2>
    <div class="article-header__meta" style="--justify: space-between;">
        <p>By Ahmad Shadeed</p>
        <p>Published under: CSS, Design</p>
    </div>
</div>

CSS

.article-header__meta {
    display: flex;    
    justify-content: var(--justify);
}

有了它,我可以调整内联样式以将值更改为另一个关键字。 我发现这在进行快速原型制作甚至是制作网站时很有用。

按钮

按钮宽度

CSS 变量也适用于按钮元素。 假设有一个带有两个input

Im folgenden Beispiel definiere ich eine globale Variable --size, die für die Breite und Höhe des square-Elements verwendet wird.

<button class="c-button" style="--width: 100%;">Submit</button>
Was tun, wenn --size nicht definiert ist? CSS unterstützt die Definition von Standardvariablen oder Fallback-Variablen, wenn die übergebenen Variablen ungültig sind. Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layoutsvar(--size, 10px) im Beispiel unten. Wenn --size ungültig ist, betragen die Werte für Breite und Höhe 10px.

.c-button {
    /* Other styles */    
    width: var(--width, initial);
}
🎜 Darüber hinaus können Sie CSS-Variablen auch in Inline-CSS-Stilen verwenden. Zum Beispiel 🎜🎜HTML🎜
<button class="c-button c-button--ghost" style="--color: #5e35b1;">Save Edits</button>
<button class="c-button c-button--ghost" style="--color: #ec2828;">Delete</button>
🎜CSS🎜
.c-button--ghost {
  /* Other styles */
  background: transparent;
  color: var(--color, #000);
  border-color: currentColor;
}
🎜Als nächstes verwenden wir die oben genannten Konzepte und demonstrieren einige Beispiele. 🎜

CSS-Rasterbeispiel🎜

Seitenleiste und Hauptinhalt

🎜🎜Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts🎜🎜🎜In diesem Design habe ich CSS Grid verwendet für: 🎜
    Seitenleiste und Hauptmenü
  1. Formularelemente
  2. Dreispaltiges Layout
🎜Die Breite der Seitenleiste ist festgelegt und der Hauptinhalt ändert sich. Angenommen, die Breite der Seitenleiste beträgt 240px. 🎜🎜1. Seitenleiste und Hauptmenü🎜🎜Html🎜
.c-avatar {
  display: inline-block;
  margin-right: 2rem;
  width: calc(var(--size, 1) * 30px);
  height: calc(var(--size, 1) * 30px);
  object-fit: cover;
  border-radius: 50%;
  box-shadow: 0 3px 10px 0 rgba(#000, 0.2);
}
🎜Html🎜
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
🎜2. Formularelemente 🎜🎜Je nach Design hat jede Zeile zwei Spalten und die HTML-Struktur ist wie folgt: 🎜🎜Html🎜rrreee🎜CSS🎜rrreee🎜3. Dreispaltiges Layout🎜🎜Im Beispiel unten habe ich --repeat-number: 3 und --gap: 8px als Inline-CSS hinzugefügt. Diese Variablen werden zur Klasse o-grid hinzugefügt und die Einstellungen des Rasters basieren auf diesen Variablen. 🎜🎜HTML🎜rrreee🎜CSS🎜rrreee🎜 Ich füge CSS-Variablen gerne Standardwerte hinzu, falls die Variable nicht gesetzt ist. Im obigen Code habe ich var(--gap, 0) verwendet. Wenn der Benutzer die Variable --gap nicht bereitstellt, ist ihr Standardwert 0. 🎜

Dynamische Rasterelemente: minmax

🎜Für mich ist dies ein weit verbreiteter Anwendungsfall und sehr wichtig. Ich verwende Grid minmax regelmäßig, aber wenn ich es auf mehreren Seiten verwende, stoße ich auf ein Problem. 🎜🎜Nehmen wir ein einfaches Beispiel ohne die Verwendung von CSS-Variablen. 🎜🎜🎜Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts🎜🎜 🎜In CSS verwende ich minmax, um eine Mindestbreite von 250px für jedes Rasterelement zu definieren. 🎜🎜CSS🎜rrreee🎜Was sollten Sie nun tun, wenn Ihr Design erfordert, dass Ihre Rasterelemente mindestens 300px breit sein müssen? Muss ich eine Version wie die folgende erstellen? 🎜rrreee🎜Stellen Sie sich vor, Sie hätten fünf verschiedene Raster mit jeweils unterschiedlichen Elementbreiten, daher ist das oben Gesagte nicht die richtige Lösung. 🎜🎜Mit CSS-Variablen kann ich die folgenden Operationen ausführen🎜rrreee🎜In HTML kann ich CSS-Variablen für Tags festlegen: 🎜rrreee
🎜Case-Quellcode: https://codepen.io/shadeed/pen/7d3e0d575a5cecb86233fc7d72fa90d4🎜

Flexbox-Beispiel 🎜🎜Im Beispiel gibt es einen Artikeltitel, der den Namen des Autors und Tags enthält. Diese Layoutmethoden auf der Seite ändern sich dynamisch, daher ist eine Methode zum schnellen Wechseln dieser Layoutmethoden erforderlich. 🎜🎜HTML🎜rrreee🎜CSS🎜rrreee🎜Damit kann ich den Inline-Stil anpassen, um den Wert auf ein anderes Schlüsselwort zu ändern. Ich finde das nützlich, wenn ich Rapid Prototyping durchführe oder sogar eine Website erstelle. 🎜

Schaltfläche 🎜

Schaltflächenbreite

🎜CSS-Variablen funktionieren auch auf Schaltflächenelementen. Angenommen, Sie haben ein Formular mit zwei Eingabefeldern und einer Schaltfläche. 🎜🎜🎜🎜🎜🎜

我的目的是通过使用内联CSS变量来控制按钮的宽度。 有时,按钮应占据其父控件的100%宽度。

html

<button class="c-button" style="--width: 100%;">Submit</button>

css

.c-button {
    /* Other styles */    
    width: var(--width, initial);
}

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

按钮颜色

另一个有用的用途是当有重影按钮(轮廓按钮)时。 按钮的颜色可以是任何颜色,通过使用CSS变量,可以轻松更改颜色。

HTML

<button class="c-button c-button--ghost" style="--color: #5e35b1;">Save Edits</button>
<button class="c-button c-button--ghost" style="--color: #ec2828;">Delete</button>

CSS

.c-button--ghost {
  /* Other styles */
  background: transparent;
  color: var(--color, #000);
  border-color: currentColor;
}

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

CSS 变量同样适合悬停效果。悬停时,按钮背景将变为纯色,并且字体颜色为白色。

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

事例源码:https://codepen.io/shadeed/pen/f8e6969d5145d4dcd81aacf7a037c995

用户头像

每个角色的大小都不同,这非常适合用 CSS 变量来解决。假设有四个不同大小的用户头像。

Tipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts

在CSS中,定义了以下样式:

.c-avatar {
  display: inline-block;
  margin-right: 2rem;
  width: calc(var(--size, 1) * 30px);
  height: calc(var(--size, 1) * 30px);
  object-fit: cover;
  border-radius: 50%;
  box-shadow: 0 3px 10px 0 rgba(#000, 0.2);
}

通过使用Calc()函数,我可以传递一个--size 变量,它将乘以一个基本宽度值,在HTML中定义 --size变量:

<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">
<img src="user.jpg" alt="" class="c-avatar"   style="max-width:90%">

事例源码:https://codepen.io/shadeed/pen/cdaac5ff667e1f7d9c8241655441f10d

英文原文地址:https://css-tricks.com/patterns-for-practical-css-custom-properties-use/

作者:Ahmad shaded

更多编程相关知识,请访问:编程入门!!

Das obige ist der detaillierte Inhalt vonTipps zur Verwendung von CSS-Variablen zur Verbesserung der Effizienz intelligenter Layouts. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:segmentfault.com. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen