CSS 状态管理,玩出花了!

开发 前端
本文介绍CSS用于交互的方式,一起来看看例子,CSS真好玩! 希望本文讲解的思路对大家有所帮助!

CSS用于交互的方式无非就那么几种:

  • 伪类:​​:hover​​、​​:link​​、​​:active​​ ...
  • 动画:​​animation​
  • 过渡动画:​​transition​

这些交互方式组合起来,真的可以玩出一些花样,例如我们本文的主题,CSS的状态管理,一起来看个例子🌰

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS状态管理</title>
    <style>
        @keyframes statement {
            0% {
                --stateinitial;
            }

            1%100% {
                --state: ;
            }
        }

        .zero2one {
            width100px;
            height100px;
            border1px solid black;
            --hovervar(--stategreen;
            backgroundvar(--hoverred);
            animationstatement 1ms linear 1 forwards paused;
        }

        .zero2one:hover {
            animation-play-staterunning;
        }
    </style>
</head>
<body>
    <div class="zero2one">零一</div>
</body>
</html>

看一下具体的效果:

小试牛刀

正方形本来是红色背景的,当我们鼠标移入后,背景颜色变为绿色,且不会再变回去。如果是普通的交互,我们应该只用到了 ​​:hover​​,鼠标移出后,元素会恢复原来的颜色,而我们现在是如何做到的呢?

这是因为我们把 "鼠标移入方框" 这个动作存储下来了!这就是 "CSS状态管理" 我们一起来解读这段代码吧!

CSS变量

来看一个CSS变量的例子

html {
  --state1initial;
  --state2: ;
}

.zero2one {
  --color1var(--state1red
  --color2var(--state2blue;  
  
  colorvar(--color1yellow);   /* 最终字体颜色为yellow */
  backgroundvar(--color2pink); /* 最终背景色为blue */
}

其实这就是借助了 ​​var()​​ 函数第一个值无效时会用第二、第三个值、第n个值作为备选值的特性(如上述代码所示)

然后还有一个骚操作就是 ​​color: var(--color1, yellow)​​ 最终会展示黄色,因为变量 ​​--color1​​ 引用了另一个变量 ​​--state1: initial​​ ,正是因为值为 ​​initial​​ ,导致最终 ​​color​​ 展示了黄色,​​--color1​​ 被认定为一个无效值

这时有人要说了,那我直接设置 ​​--color1: initial red;​​ 不就好了,为啥还要多引一个变量呢?我试过了,这样直接写是没用的,别问,问就是我也不知道!(有知道的小伙伴可以评论区告诉我~)

然后变量 ​​--color2​​ 引用了变量 ​​--state2: ;​​,因为其值为空,所以其实变量 ​​--color2​​ 对应的也就是 ​​blue​​ ,那么 ​​var(--color2, pink)​​ 自然也是展示蓝色了

变量切换

借助刚刚了解的CSS变量的特性,我们可以让某个变量切换其值即可实现CSS的状态切换,如何不借助 JS 实现对CSS变量的切换呢?这时候就要借助我们文章开头提到的 ​​animation​​ 了

先定义一个 ​​keyframes​

@keyframes statement {
  0% {
    --stateinitial;
  }

  1%100% {
    --state: ;
  }
}

初始状态时将变量 ​​--state​​ 的值定义为 ​​initial​​,非初始状态将变量 ​​--state​​ 的值定义为空

好像还是没有讲到如何切换。此时可以借助一个CSS属性 ​​animation-play-state​​ ,其控制了元素动画的运动状态,假设我们一开始给某个元素设置的运动状态为 ​​paused​

.zero2one {
  animationstatement 1ms linear 1 forwards paused;
}

一开始该元素就是暂停状态,所以根据我们定义的 ​​keyframes​​ 的初始状态来看,此时全局有一个变量 ​​--state​​,值为 ​​initial​

然后可以在用户进行某些操作(​​:hover​​、​​:active​​等等)后,将该元素运动状态改为 ​​running​

.zero2one:hover {
  animation-play-staterunning;
}

当将元素的动画状态设为 ​​running​​ 后,其动画已经不是初始状态了,并且因为我们设置了 ​​forwards​​ ,所以此时全局有一个变量 ​​--state​​,其值为空

这样就做到了变量的动态切换

将上述两个技巧组合在一起,就实现了简易版的"CSS状态管理"

实战应用

由此还引申出了一个比较有意思的东西,那就是CSS实现画板!相信你们原理都懂了,那就直接放代码吧~

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>CSS状态管理</title>
    <style>
        @keyframes statement {
            0% {
                --stateinitial;
            }

            1%100% {
                --state: ;
            }
        }

        .zero2one {
            backgroundrgba(222 222 255 / 0.125);
            border1px solid #eee;
            displayinline-block;
        }

        li {
            list-stylenone;
            displayinline-block;
            margin0;
            padding0;
            width3px;
            height3px;
            floatleft;
            --bg-colorvar(--stategreen;
            backgroundvar(--bg-colortransparent);
            animationstatement 1ms linear 1 forwards paused;
        }

        li:hover {
            animation-play-staterunning;
        }
    </style>
</head>
<body>
    <ul class="zero2one">
      <li></li>
      <li></li>
      <!-- 此处省略 10000个li标签 -->
    </ul>
</body>
</html>

最终实现效果就是这样的,如下图所示:

CSS画板

CSS真好玩! 希望本文讲解的思路对大家有所帮助。

责任编辑:庞桂玉 来源: 前端大全
相关推荐

2023-10-24 09:53:56

自动驾驶模型

2021-12-14 10:54:31

TopK面试排序法

2022-03-29 20:10:27

React状态管理

2024-04-07 13:31:51

谷歌VLOGGER视频

2021-09-01 08:32:13

CSS 技巧@property

2022-09-26 20:19:05

CSS​技巧JS​

2022-06-20 09:01:50

SwiftUI状态管理系统

2022-05-09 08:01:23

countdistinctMySQL

2021-08-04 12:26:00

Postman工具频率

2021-06-11 06:45:32

SQL结构化语言

2021-03-06 22:21:58

分号代码 语言

2016-11-04 23:37:30

虚拟化混合云云计算

2016-10-13 13:43:55

混合云云计算数据中心

2022-08-17 10:07:52

VueVue 3

2022-11-02 09:39:51

数据恢复Kubernetes

2010-09-09 08:33:00

2023-02-15 09:00:49

2021-04-29 09:31:05

前端开发技术

2016-09-06 22:05:41

HttpCookieWeb

2024-04-22 09:12:39

Redux开源React
点赞
收藏

51CTO技术栈公众号