Heim > Web-Frontend > CSS-Tutorial > Kann ich CSS-Variablen innerhalb einer „url()'-Funktion verwenden?

Kann ich CSS-Variablen innerhalb einer „url()'-Funktion verwenden?

Mary-Kate Olsen
Freigeben: 2024-12-09 21:47:10
Original
942 Leute haben es durchsucht

Can I Use CSS Variables Inside a `url()` Function?

Kann ich CSS-Variablen innerhalb eines URL-Ausdrucks interpolieren?

In CSS bieten benutzerdefinierte Eigenschaften (auch als CSS-Variablen bezeichnet) eine praktische Möglichkeit um Werte programmgesteuert zu speichern und zu ändern. Benutzer können jedoch auf Einschränkungen stoßen, wenn sie versuchen, Variablenwerte innerhalb der URL-Funktion zu interpolieren, beispielsweise in der Hintergrundeigenschaft.

Beispiel:

:root {
  --url: "https://download.unsplash.com/photo-1420708392410-3c593b80d416";
}

body {
  background: url(var(--url));
}
Nach dem Login kopieren

Leider ist eine solche Interpolation innerhalb der nicht möglich url()-Funktion aus veralteten Gründen. CSS-Parser behandeln url(var(--url)) nicht als separate Token, sondern als einzelnes ungültiges url()-Token.

Obwohl Interpolation allgemein für CSS-Funktionen wie rgba() verfügbar ist, ist sie für nicht zulässig url() aufgrund möglicher Mehrdeutigkeiten und Analyseprobleme.

Daher ist es sinnvoll, die gesamte URL-Zeichenfolge innerhalb der benutzerdefinierten Eigenschaft explizit zu definieren notwendig:

:root {
  --url: url("https://download.unsplash.com/photo-1420708392410-3c593b80d416");
}

body {
  background: var(--url);
}
Nach dem Login kopieren

Alternativ kann JavaScript verwendet werden, um die gewünschte Interpolation durchzuführen.

Das obige ist der detaillierte Inhalt vonKann ich CSS-Variablen innerhalb einer „url()'-Funktion verwenden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage