Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CSS 函数 #10

Open
wild2life opened this issue Dec 19, 2024 · 0 comments
Open

CSS 函数 #10

wild2life opened this issue Dec 19, 2024 · 0 comments

Comments

@wild2life
Copy link
Owner

CSS 函数

早上刷推看到的一个图

1F84C7046D0DD6DD8C98FD7E21475F4D

min()

计算表达式的值中最小的值作为参数值

类似 JS 中的 Math.min()

示例

width: min(50vw, 500px);

表示元素最大宽为 500px,即:小屏设备上宽度为 window 的一半,但在小屏设备上,不超过 500px

max()

计算表达式的值中最大的值作为参数值,用法和 min 一致

clamp()

返回一个区间范围的值

语法: clamp(MIN, VAL, MAX)MIN 表示最小值,VAL 表示首选值,MAX 表示最大值,即 VALMIN MAX 之间就用 VAL,比 MIN 小就用 MIN ,比 MAX 大就用 MAX

等同于 max(MIN, min(VAL, MAX))

组合使用

min() max() clamp() 这三哥们都是比较新的属性,兼容性都不咋地,仅用于个人玩具

image

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Static Template</title>
    <style>
      .min {
        /* width: min(20px, 30px, 40px); */
        width: min(2rem, 15vw);
        height: 100px;
        font-size: min(16px, 10vw);
        line-height: min(16px, 10vw);
        background: forestgreen;
      }
      .max {
        width: max(2rem, 15vw);
        height: 100px;
        font-size: max(16px, 10vw);
        line-height: max(16px, 10vw);
        background: red;
      }
      .clamp {
        width: clamp(2rem, 40px, 15vw);
        height: 100px;
        background: blue;
      }
      .min-calc {
        width: max(calc(100vw - 20px - 3rem - 20vh), 40px);
        height: 100px;
        background: orange;
      }
    </style>
  </head>
  <body>
    <div class="min">min</div>
    <div class="max">max</div>
    <div class="clamp">clamp</div>
    <div class="min-calc">min calc</div>
  </body>
</html>

demo

顺便总结了下 CSS 的函数

数学函数

  • min() 计算表达式的值中最小的值作为参数值
    • width: min(50vw, 500px);
  • max() 计算表达式的值中最大的值作为参数值
    • width: max(50vw, 500px);
  • clamp() 返回一个区间范围的值
    • width: clamp(10px, 1em, 20px);
  • calc() 在声明 CSS 属性值时执行一些计算
    • width: calc(100% - 100px);
  • minmax()gird 布局中使用,定义了一个长宽范围的闭区间
  • repeat()gird 布局中使用,表示轨道列表的重复片段
  • attr() 获取选择到的元素的某一 HTML 属性值
    • a:before { content:attr(data-name); }

颜色函数

  • rgb() 使用红-绿-蓝(red-green-blue (RGB))定义颜色
    • color: rgb(123, 123, 123);
  • rgba()rgb 的基础上增加了阿尔法通道(A)
    • color: rgba(123, 123, 123, 0.23);
  • hsl() 使用色相-饱和度-明度(Hue-saturation-lightness)定义颜色
    • color: hsl(120, 100%, 75%);
  • hsla()hsl 的基础上增加了阿尔法通道(A)
    • color: hsla(120, 100%, 75%, 0.5);

背景图函数

  • url() 指向一个资源
    • background: url('img.png');
  • linear-gradient() 创建一个线性渐变
    • background-image: linear-gradient(45deg, blue, red);
    • background-image: linear-gradient(to left top, blue, red);
  • radial-gradient() 创建一个径向渐变
    • background-image: radial-gradient(circle, red, yellow, green);
  • repeating-linear-gradient() 创建重复的线性渐变
    • background-image: repeating-linear-gradient(red, yellow 10%, green 20%);
  • repeating-radial-gradient() 创建重复的径向渐变
    • background-image: repeating-radial-gradient(red, yellow 10%, green 15%);

动画缓动函数

其他函数

  • var() 用于插入自定义的属性值
    • width: var(--main-wdith);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant