• 纯CSS实现点击动画


    方法一::checked

    在这里插入图片描述

    使用 label 标签 + input::checkbox 标签实现点击

    label标签的作用:点击label内部文本可以触发该控件,实现点击选择框或文字都可以出现动画效果
    input:checkbox的用途:含有checked属性实现选中未选择变化

    <label class="label">
    	<input type="checkbox" class="select" hidden />
    	<span class="check">我是文字我是文字我是文字span>
    label>
    
    • 1
    • 2
    • 3
    • 4
    .label {
      margin-bottom: 10px;
    }
    .select {
      /* display: none; */
      /* appearance: none; // 清除原生样式 */
    }
    
    
    .check {
      position: relative;
      color: #fff;
      font-size: 1rem;
      height: 1.5rem;
      line-height: 1.5;
      cursor: pointer;
      user-select: none;
      transition: 0.3s;
      &::before {
        content: "";
        position: absolute;
        left: -2.5rem;
        width: 25px;
        height: 25px;
        border: 2px solid #f1faee;
        transition: 0.2s;
      }
      &::after {
        content: "";
        position: absolute;
        top: 50%;
        left: 0;
        width: 100%;
        height: 1px;
        background-color: #f1faee;
        transform: scale(0);
        transform-origin: right;
        transition: transform 0.5s;
      }
    }
    
    .select:checked + .check {
      color: #585b57;
      &::before {	// 框动画
        width: 25px;
        height: 15px;
        border-top: transparent;
        border-right: transparent;
        transform: rotate(-45deg);
      }
      &::after {	// 线动画
        transform: scale(1);
        transform-origin: left;
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55

    方法二::target

    # 锚的名称是在一个文件中链接到某个元素的URL。元素被链接到目标元素。

    :target 选择器可用于当前活动的target元素的样式。
    在这里插入图片描述

    在这里插入图片描述

    #select:target{
      color: #585b57;
      &::before {
        width: 25px;
        height: 15px;
        border-top: transparent;
        border-right: transparent;
        transform: rotate(-45deg);
      }
      &::after {
        transform: scale(1);
        transform-origin: left;
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    暂不推荐该方法,a标签会跳转页面,且不能直接第二次点击取消样式,需要设置href和id

  • 相关阅读:
    【SpringCloud-学习笔记】初识Docker
    高并发使用JVM锁和MySQL锁解决数据不一致问题
    JavaScript高级知识-ES5~6
    一、尚医通预约下单
    NLLLOSS & CrossEntropyLoss
    『 CSS实战』CSS3 实现一些好玩的效果(1)
    面试买书复习就能进大厂?
    zoneinfo
    ZMQ之异步管家模式
    《CPU通识课》读书笔记
  • 原文地址:https://blog.csdn.net/wgh4318/article/details/126597910