CSS变量是怎么工作的?如何使用内联CSS变量进行布局?

本篇文章带大家了解一下css变量,聊聊css变量是怎么工作的,并介绍一下如何使用内联css变量,以提高灵巧布局效率,希望对大家有所帮助!

CSS变量是怎么工作的?如何使用内联CSS变量进行布局?

有些情况下,我需要用一种简单的方法来创建网格布局。 例如,每次我改变主意时,在不修改CSS的情况下快速画出五列网格。 在本文中,我们一起探索一些用例,并思考如果实现及使用它们。【推荐学习:css视频教程】

它是怎么工作的

在深入探讨这些概念之前,首先我们来回顾一下 CSS 变量的基础知识, 我们也可以将它称为“自定义属性”。

所有主流浏览器都支持CSS变量,下面是各个浏览器的支持情况:

立即学习“前端免费学习笔记(深入)”;

clipboard.png

如果要定义CSS变量是全局变量,则需要将其添加到: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

CSS

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

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

大家都说简历没项目写,我就帮大家找了一个项目,还附赠【搭建教程】。

CSS网格示例

侧边栏和主内容

图片描述

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

边栏和主菜单

表单项

三列布局

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

1.边栏和主菜单

Html

Html

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

2. 表单项

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

Html

CSS

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

3. 三列布局

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

HTML

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 变量的基本示例。

clipboard.png

在 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 变量:

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

Flexbox示例

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

HTML

Article title

By Ahmad Shadeed

Published under: CSS, Design

CSS

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

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

按钮

按钮宽度

CSS 变量也适用于按钮元素。 假设有一个带有两个input字段和一个按钮的表单。

clipboard.png

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

html

css

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

clipboard.png

按钮颜色

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

HTML

CSS

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

clipboard.png

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

图片描述

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

用户头像

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

clipboard.png

在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变量:

@@##@@@@##@@@@##@@@@##@@

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

作者:Ahmad shaded

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

(学习视频分享:web前端)

CSS变量是怎么工作的?如何使用内联CSS变量进行布局?CSS变量是怎么工作的?如何使用内联CSS变量进行布局?CSS变量是怎么工作的?如何使用内联CSS变量进行布局?CSS变量是怎么工作的?如何使用内联CSS变量进行布局?

以上就是CSS变量是怎么工作的?如何使用内联CSS变量进行布局?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1624132.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 08:28:04
下一篇 2025年12月24日 08:28:20

相关推荐

  • 深入探究CSS鼠标指针交互效果

    今天,来实现这样一个有意思的交互效果,通过这个交换效果来聊聊前端鼠标指针交互,希望对大家有所帮助! 将原本的鼠标指针样式,修改成自己想要的效果,并且添加上一些特殊的交互效果。【推荐学习:css视频教程】 修改鼠标样式 首先,第一个问题,我们可以看到,上图中,鼠标指针的样式被修改成了一个圆点: 立即学…

    2025年12月24日 好文分享
    000
  • 纯CSS3怎么实现波浪效果?(代码示例)

    纯css3怎么实现波浪效果?本篇文章就来给大家介绍一下使用 svg 和 css 动画制作波浪效果的方法,希望对大家有所帮助!         随着前端技术的不断发展与进步,界面交互的样式要求和美感也越来越高,很多网页的交互都加上了css3动画,这里作者给大家分享一个前端开发必掌握的一个CSS3波浪效…

    2025年12月24日
    000
  • CSS3动画实战之:超酷炫的粘性气泡效果

    本篇文章带大家聊聊css3动画,看看怎么使用纯 css 实现超酷炫的粘性气泡效果,希望对大家有所帮助! 最近,在 CodePen 上看到这样一个非常有意思的效果: 这个效果的核心难点在于气泡的一种特殊融合效果。【推荐学习:css视频教程】 立即学习“前端免费学习笔记(深入)”; 其源代码在:Code…

    2025年12月24日 好文分享
    000
  • 什么是BFC?深入了解BFC,聊聊作用

    什么是bfc?下面本篇文章带大家了解一下bfc,并聊聊bfc的作用。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 之前在面试字节的时候,面试官问了我有了解BFC吗,我当时其实有看很多文章,但是总是记不住,感觉每个文章讲的都差不多,然后面试时候也没答出来,但是在听了王红元老师讲解的…

    2025年12月24日 好文分享
    000
  • 利用纯CSS如何在滚动时自动添加头部阴影

    利用纯css如何在滚动时自动添加头部阴影?下面本篇文章给大家介绍一下css层级小技巧!看看在滚动时自动添加头部阴影的方法,希望对大家有所帮助! 在网页中,经常会用阴影来突出层级关系,特别是顶部导航,但有时候设计觉得没必要一开始就显示阴影,只有滚动后才出现。比如下面这个例子,注意观察头部阴影。【推荐学…

    2025年12月24日 好文分享
    000
  • 聊聊怎么巧用CSS给普通黑色二维码添上彩色渐变!

    怎么巧用 css 构建渐变彩色二维码?下面本篇文章就来给大家介绍一下利用css给普通黑色二维码添上彩色渐变的方法,希望对大家有所帮助! 今日,群里有个很有意思的问题,问我如何实现一个彩色的,带渐变的二维码,像是这样: 很有意思的问题,我们在百度谷歌,搜索 qrcode,能搜到非常多在线制作二维码的工…

    2025年12月24日 好文分享
    000
  • 聊聊CSS3中的4个逻辑选择器(快速入手)

    本篇文章给大家介绍一下css3中的逻辑选择器,聊聊里面的 4 名成员,希望对大家有所帮助! 在 CSS 选择器家族中,新增这样一类比较新的选择器 — 逻辑选择器,目前共有 4 名成员: :is:where:not:has 本文将带领大家了解、深入它们。做到学以致用,写出更现代化的选择器。…

    2025年12月24日 好文分享
    000
  • 利用CSS也可以处理图片,转为“像素风”!

    如何把图片变成“伪像素风”?本篇文章给大家介绍一下使用css处理图片,将其转为“像素风”的方法,希望对大家有所帮助! 什么是像素风? 像素风是一种以固定大小纯色像素方块作为基本单元,进行创作,包含但不限于绘画、建筑、游戏更各个领域的一种美术风格。其中最让人耳熟能详的,当然是早期电子游戏的像素画面啦~…

    2025年12月24日 好文分享
    000
  • CSS如何进行性能优化?优化小技巧分享

    css如何进行性能优化?下面本篇文章给大家介绍一些css性能优化的小技巧,希望对大家有所帮助! 随着互联网发展至今,对于网站来说,性能显的越来越重要了,CSS作为页面渲染和内容展现的重要环节,影响着用户对整个网站的第一体验。所以,我们需要重视与CSS相关的性能优化。【推荐学习:css视频教程】 项目…

    2025年12月24日
    000
  • 神奇的CSS,实现自动补全字符串!

    本篇文章给大家介绍使用css的实用小技巧,了解一下css自动补全字符串的几种方法,希望对大家有所帮助! 很多时候都会碰到字符串补全的需求,典型的例子就时间或者日期中的补零操作,例如 2021-12-312022-03-03 通常的做法是 if (num < 10) { num = '…

    2025年12月24日 好文分享
    000
  • 聊聊怎么使用CSS滤镜实现内凹平滑圆角效果

    怎么利用css实现内凹平滑圆角效果?下面本篇文章带大家了解一下怎么巧用css滤镜实现内凹平滑圆角效果,希望对大家有所帮助! 某日,群友们在群里抛出这样一个问题,如何使用 CSS 实现如下的布局: 在 CSS 世界中,如果只是下述这种效果,还是非常容易实现的: 立即学习“前端免费学习笔记(深入)”; …

    2025年12月24日 好文分享
    000
  • 一文了解CSS3中的新特性@layer

    本篇文章带大家一起深入了解一下css3中的新特性@layer,希望对大家有所帮助! 步入 2022,CSS 的新特性层出不穷,而最近在 CSS 圈最受瞩目的新特性,非 CSS @layer 莫属。 本文,将用最简洁的语言,快速让读者们搞懂,到底什么是 CSS @layer 新规范。 过往 CSS 优…

    2025年12月24日 好文分享
    000
  • css3包含C语言程序设计吗

    css3不包含C语言程序设计。css3是一种用来表现HTML或XML等文件样式的计算机语言,而C语言程序设计是一种通用的程序设计语言,二者之间不存在包含与被包含的关系。 本教程操作环境:windows10系统、CSS3&&HTML5版、Dell G3电脑。 css3包含C语言程序设计…

    2025年12月24日
    000
  • css3链接怎么设置为没有手的样式

    在css中,可以利用cursor属性设置链接上没有小手的样式,该属性用于定义了鼠标指针放在一个元素边界范围内时所用的光标形状,当属性值设置为default时,鼠标样式为普通箭头样式,语法为“cursor:default;”。 本教程操作环境:windows10系统、CSS3&&HTM…

    2025年12月24日
    000
  • 分享10个纯 CSS 实现的 Loading 效果

    我们遇到加载,要么是ui框架中自带,要么就是百度,然后cv到项目中?但是,自己实现的时候,又会没有思路。下面本篇文章就来给大家分享10个纯 css 实现的 loading 效果,希望对大家有所帮助! 在推特上面看到 T. Afif 介绍的十个 Loading 效果。如上图。 Yeah,很赞哦,挺实用…

    2025年12月24日 好文分享
    000
  • 聊聊使用CSS怎么实现毛玻璃特效(兼容方案探究)

    使用css怎么实现毛玻璃特效?下面本篇文章给大家介绍一下使用css实现毛玻璃特效(兼容方案探究)的方法,希望对大家有所帮助! 前一段时间在某项目中用到了“高斯模糊”的滤镜效果,过程中尝试了多种方案,这里总结一种方式,希望可以帮助到有需要的道友~ UI 小姐姐非要让我在 Android 系统自定义的 …

    2025年12月24日 好文分享
    000
  • 浅析CSS中怎么实现线性渐变(linear-gradient)

    css中怎么实现线性渐变?下面本篇文章给大家介绍一下css线性渐变函数linear-gradient()的使用方法,并聊聊线性渐变的多种应用,希望对大家有所帮助! linear-gradient 1. 语法 linear-gradient([[to |],]? , [, …]?)的使用 二者表现…

    2025年12月24日 好文分享
    000
  • 如何利用CSS制作一个聚光灯效果(附代码)

    如何利用css制作一个聚光灯效果?下面本篇文章给大家分析一下实现原理,分享一下css聚光灯效果的实现代码,希望对大家有所帮助! CSS聚光灯效果的实现原理很简单: 将两个文字完全重叠,内层是深灰色,外层是有渐变颜色的。【推荐学习:css视频教程】在将外层的文字套用圆形遮罩。最后加上 CSS Anim…

    2025年12月24日
    000
  • 一文了解CSS3中的新特性 ::target-text 选择器

    本篇文章带大家一起深入了解一下css3中的新特性::target-text 选择器,聊聊该选择器的作用和使用方法,希望对大家有所帮助! 最近在 MDN 官网看到了一个从未见过的选择器,::target-text。 简单研究了一下,觉得还有点意思,也有点实际用处,现在分享一下。【推荐学习:css视频教…

    2025年12月24日 好文分享
    000
  • 纯CSS实现水波纹的电池充电动画特效

    本篇文章给大家介绍一下巧用 css实现水波纹的电池充电动画特效的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 我们知道构成前端的三大语言有:html、css和js,其中最为神秘的便是css,为什么这么说呢?自从动画、过度等属性的出现,可以说只有你想不到,就没有做不到~ 上一…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信