函数

CSS 播客 - 020:函数

到目前为止,您已经在本课程中了解了几个 CSS 函数。在 grid 模块中,我们介绍了 minmax()fit-content(),它们可以帮助您调整元素大小。在 color 模块中,我们介绍了 rgb()hsl(),它们可帮助您定义颜色。

与许多其他编程语言一样,CSS 提供了大量内置函数,您可以在需要时随时访问它们。

每个 CSS 函数都有特定的用途。在本课程中,您将大致了解这些函数,从而更好地了解它们的使用场景和使用方式。

什么是函数?

函数是完成特定任务的独立命名代码段。 由于已命名函数,因此您可以在代码中调用该函数,并可向该函数传递数据。这称为传递参数。

上述函数示意图

许多 CSS 函数都是纯函数,也就是说,如果您将相同的参数传递给函数,则无论您代码的其余部分发生了什么,它们都会返回相同的结果。当 CSS 中的值发生更改时,这些函数通常会重新计算,类似于该语言中的其他元素,例如计算的级联值,例如 currentColor

在 CSS 中,您只能使用所提供的函数,而不能自行编写函数,但在某些情况下,函数可以相互嵌套,从而赋予它们更大的灵活性。我们将在本单元后面的部分对此进行详细介绍。

功能选择器

.post :is(h1, h2, h3) {
    line-height: 1.2;
}

您学习了伪类模块中的功能选择器,其中详细介绍了 :is():not() 等函数。传递到这些函数的参数为 CSS 选择器,然后对它们进行求值。 如果存在与元素匹配的元素,则系统会将其余 CSS 规则应用于这些元素。

自定义属性和 var()

:root {
    --base-color: #ff00ff;
}

.my-element {
    background: var(--base-color);
}

自定义属性是一种变量,可用于对 CSS 代码中的值进行标记化。自定义属性也会受级联的影响,这意味着可以在上下文中操作或重新定义自定义属性。自定义属性必须以两个短划线 (--) 为前缀,并且区分大小写。

var() 函数接受一个必需参数:您尝试作为值返回的自定义属性。在上面的代码段中,var() 函数将 --base-color 作为参数传递。如果定义了 --base-color,则 var() 将返回该值。

.my-element {
    background: var(--base-color, hotpink);
}

您还可以将回退声明值传入 var() 函数。这意味着,如果找不到 --base-color,系统会改用所传递的声明,在本例中,该声明为 hotpink 颜色。

返回值的函数

var() 函数只是一个可返回值的 CSS 函数。attr()url() 等函数遵循与 var() 类似的结构,您需要传递一个或多个参数,并在 CSS 声明的右侧使用它们。

a::after {
  content: attr(href);
}

这里的 attr() 函数会获取 <a> 元素的 href 属性的内容,并将其设为 ::after 伪元素的 content。如果 <a> 元素的 href 属性的值发生更改,这会自动反映在此 content 属性中。

.my-element {
    background-image: url('/path/to/image.jpg');
}

url() 函数采用字符串网址作为参数,用于加载图片、字体和内容。 如果未传入有效网址或找不到网址指向的资源,则 url() 函数不会返回任何内容。

颜色函数

您已经在 color 模块中全面了解了颜色函数。如果您还没有读过此类内容,强烈建议您读一读。

CSS 中一些可用的颜色函数包括 rgb()rgba()hsl()hsla()hwb()lab()lch()。所有这些对象的形式都类似,其中传入配置参数,然后返回颜色。

数学表达式

与许多其他编程语言一样,CSS 也提供实用的数学函数来协助进行各种类型的计算。

calc()

浏览器支持

  • 26
  • 12
  • 16
  • 7

来源

calc() 函数接受单个数学表达式作为其参数。此数学表达式可以组合多种类型,如长度、数字、角度和频率。单位也可以混用。

.my-element {
    width: calc(100% - 2rem);
}

在此示例中,calc() 函数用于将某个元素的宽度调整为其所属父元素的 100%,然后移除该计算值的 2rem

:root {
  --root-height: 5rem;
}

.my-element {
  width: calc(calc(10% + 2rem) * 2);
  height: calc(var(--root-height) * 3);
}

calc() 函数可以嵌套在另一个 calc() 函数中。您还可以将自定义属性作为表达式的一部分在 var() 函数中传递。

min()max()

浏览器支持

  • 79
  • 79
  • 75
  • 11.1

来源

min() 函数会返回一个或多个已传递参数的最小计算值。max() 函数则相反:获取一个或多个传递的参数中的最大值。

.my-element {
  width: min(20vw, 30rem);
  height: max(20vh, 20rem);
}

在此示例中,宽度应为 20vw(视口宽度的 20%)和 30rem 之间的最小值。高度应为 20vh(即视口高度的 20%)到 20rem 之间的最大值。

clamp()

浏览器支持

  • 79
  • 79
  • 75
  • 13.1

来源

clamp() 函数采用三个参数:最小大小、理想大小和最大大小。

h1 {
  font-size: clamp(2rem, 1rem + 3vw, 3rem);
}

在此示例中,font-size 将根据视口的宽度保持自适应。将 vw 单位添加到 rem 单位以帮助进行屏幕缩放,因为无论缩放级别如何,vw 单位的大小都是相同的。根据根字字体大小乘以 rem 单位,可以为 clamp() 函数提供相对计算点。

如需详细了解 min()max()clamp() 函数,请参阅这篇文章

形状

clip-pathoffset-pathshape-outside CSS 属性使用形状直观地裁剪方框或提供形状,让内容四处移动。

有一些形状函数可用于这两种属性。circle()ellipse()inset() 等简单形状可使用配置参数来确定其大小。更复杂的形状(例如 polygon())可使用逗号分隔的 X 轴和 Y 轴值对来创建自定义形状。

.circle {
  clip-path: circle(50%);
}

.polygon {
  clip-path: polygon(0% 0%, 100% 0%, 100% 75%, 75% 75%, 75% 100%, 50% 75%, 0% 75%);
}

polygon() 一样,还有一个 path() 函数,该函数接受 SVG 填充规则作为参数。因此,可以使用 Illustrator 或 Inkscape 等图形工具绘制高度复杂的形状,然后将其复制到 CSS 中。

变形

在本 CSS 函数的概览中,最后介绍的是转换函数,用于倾斜、调整大小甚至更改元素的深度。以下所有函数均与 transform 属性一起使用。

Rotation

浏览器支持

  • 1
  • 12
  • 3.5
  • 3.1

来源

您可以使用 rotate() 函数旋转元素,该函数会围绕元素的中心轴旋转元素。您还可以改用 rotateX()rotateY()rotateZ() 函数,让元素在特定轴上旋转。您可以通过传递角度、转弯和弧度单位来确定旋转角度。

.my-element {
  transform: rotateX(10deg) rotateY(10deg) rotateZ(10deg);
}

rotate3d() 函数采用四个参数。

浏览器支持

  • 12
  • 12
  • 10
  • 4

来源

前 3 个参数是数字,用于定义 X、Y 和 Z 坐标。第四个参数是旋转,与其他旋转函数一样,它接受角度、角度和转弯。

.my-element {
  transform: rotate3d(1, 1, 1, 10deg);
}

扩缩

浏览器支持

  • 1
  • 12
  • 3.5
  • 3.1

来源

您可以使用 transformscale() 函数更改元素的缩放比例。该函数接受一个或两个数字作为值,用于确定正类别或负比例。 如果您只定义一个数字参数,X 轴和 Y 轴都将按相同的缩放比例进行缩放,因此定义两者是 X 和 Y 的简写形式。与 rotate() 类似,有 scaleX()scaleY()scaleZ() 函数可用于在特定轴上缩放元素。

.my-element {
  transform: scaleX(1.2) scaleY(1.2);
}

rotate 函数一样,还有一个 scale3d() 函数。这与 scale() 类似,但使用三个参数:X、Y 和 Z 缩放比例。

翻译

浏览器支持

  • 1
  • 12
  • 3.5
  • 3.1

来源

translate() 函数会在元素保持其在文档流中的位置时移动元素。它们接受长度和百分比值作为参数。 如果定义了一个参数,translate() 函数会沿 X 轴平移元素;如果定义了两个参数,则函数会沿 X 轴和 Y 轴平移元素。

.my-element {
  transform: translatex(40px) translatey(25px);
}

与其他转换函数一样,您可以使用 translateXtranslateYtranslateZ 为特定轴使用特定函数。您还可以使用 translate3d,它允许您在一个函数中定义 X、Y 和 Z 平移。

偏差

浏览器支持

  • 1
  • 12
  • 3.5
  • 3.1

来源

您可以使用接受角度作为参数的 skew() 函数使元素倾斜。skew() 函数的工作方式与 translate() 非常相似。如果您只定义一个参数,则只会影响 X 轴;如果您同时定义了这两个参数,则会影响 X 轴和 Y 轴。您还可以使用 skewXskewY 分别影响每个轴。

.my-element {
  transform: skew(10deg);
}

车头朝上

浏览器支持

  • 36
  • 12
  • 16
  • 9

来源

最后,您可以使用 perspective 属性(属于转换属性系列的一部分)来更改用户与 Z 平面之间的距离。这种方式可以呈现距离感,并可用于在设计中实现景深。

David Desandro 编写的这个示例来自他们的实用文章,展示了如何使用它以及 perspective-origin-xperspective-origin-y 属性来打造真正的 3D 体验。

动画函数、渐变和滤镜

CSS 还提供一些函数来帮助您为元素添加动画效果、对其应用渐变,以及使用图形过滤器来操纵元素的外观。 为了使本单元尽可能简洁明了,链接的模块中会对其进行介绍。 它们都遵循与本单元演示的函数类似的结构。

检查您的掌握程度

检验您对函数知识的掌握情况

CSS 函数可以通过哪些字符来识别?

[]
以下字符适用于 JavaScript 中的数组。
{}
这些字符会封装 CSS 中的规则。
()
函数会使用这些字符来封装参数!
::
这些字符适用于 CSS 中的伪元素。
:
这些字符适用于 CSS 中的伪类。

CSS 是否具有内置数学函数?

True
代码非常多,而且我们正在向规范和浏览器添加更多代码!
False
再试一次!

calc() 函数可以放在另一个 calc()(如 font-size: calc(10px + calc(5px * 3));)内

True
🎉
False
再试一次!

以下哪些是 CSS 形状函数?

ellipse()
🎉
square()
再试一次!
circle()
🎉
rect()
再试一次!
inset()
🎉
polygon()
🎉