购物车按钮

news2025/1/20 13:28:12

先看效果:
在这里插入图片描述
再看代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>购物车按钮展示</title>
  <link href="https://fonts.googleapis.com/css?family=Inter:400,500,600,700&amp;display=swap" type="text/css" rel="stylesheet">
  <script src="https://unpkg.co/gsap@3/dist/gsap.min.js"></script>
  <script src="https://assets.codepen.io/16327/Physics2DPlugin3.min.js"></script>
  <script src="https://assets.codepen.io/16327/MorphSVGPlugin3.min.js"></script>

  <style>
    .add-to-cart {
      --color: #000;
      --background: #fff;
      --drop: #38E739;
      --background-s: 1;
      --text-o: 1;
      --text-x: 10px;
      --bottle-x: -40%;
      --bottle-y: -60px;
      --bottle-s: .4;
      --bottle-r: 0deg;
      --bottle-o: 0;
      --cart-x: -57px;
      --cart-y: -2px;
      --cart-r: 0deg;
      --cart-s: 0.8;
      --check-y: 0px;
      --check-s: 0;
      --check-offset: 8.5px;
      -webkit-tap-highlight-color: transparent;
      -webkit-appearance: none;
      outline: none;
      background: none;
      border: none;
      padding: 12px 0;
      margin: 0;
      width: 142px;
      color: var(--color);
      cursor: pointer;
      position: relative;
      text-align: center;
      font: inherit;
    }
    .add-to-cart.clipped {
      -webkit-clip-path: polygon(0 -80px, 100% -80px, 100% 80px, 0 80px);
      clip-path: polygon(0 -80px, 100% -80px, 100% 80px, 0 80px);
    }
    .add-to-cart .background,
    .add-to-cart .cart,
    .add-to-cart .check {
      position: absolute;
      pointer-events: none;
    }
    .add-to-cart .background {
      left: 0;
      top: -4px;
      right: 0;
      bottom: 0;
      display: block;
      fill: var(--background);
      transform: scale(var(--background-s)) translateZ(0);
    }
    .add-to-cart span {
      position: relative;
      z-index: 1;
      line-height: 18px;
      display: block;
      font-size: 14px;
      font-weight: 500;
      opacity: var(--text-o);
      transform: translateX(var(--text-x)) translateZ(0);
    }
    .add-to-cart .drop {
      position: absolute;
      z-index: 1;
      left: 70px;
      top: 8px;
      width: 4px;
      height: 4px;
      border-radius: 50%;
      background: var(--drop);
    }
    .add-to-cart .cart {
      z-index: 2;
      bottom: 11px;
      left: calc(50% - 2px);
      transform-origin: 10px 17px;
      transform: translate(var(--cart-x), var(--cart-y)) scale(var(--cart-s)) rotate(var(--cart-r)) translateZ(0);
    }
    .add-to-cart .cart svg {
      display: block;
      width: 24px;
      height: 19px;
      stroke: var(--color);
      stroke-linecap: round;
      stroke-linejoin: round;
      fill: none;
      position: relative;
      z-index: 1;
      transform: translateZ(0);
    }
    .add-to-cart .cart img {
      display: block;
      position: absolute;
      bottom: 7px;
      left: 50%;
      opacity: var(--bottle-o);
      transform-origin: 50% 100%;
      transform: translate(var(--bottle-x), var(--bottle-y)) scale(var(--bottle-s)) rotate(var(--bottle-r)) translateZ(0);
    }
    .add-to-cart .check {
      bottom: 0;
      left: 50%;
      padding: 2px;
      background: var(--background);
      border-radius: 50%;
      transform: translate(-50%, var(--check-y)) scale(var(--check-s)) translateZ(0);
    }
    .add-to-cart .check svg {
      display: block;
      width: 10px;
      height: 10px;
      fill: none;
      stroke-width: 1.5;
      stroke-linecap: round;
      stroke-linejoin: round;
      stroke: var(--color);
      stroke-dasharray: 8.5px;
      stroke-dashoffset: var(--check-offset);
    }

    html {
      box-sizing: border-box;
      -webkit-font-smoothing: antialiased;
    }

    * {
      box-sizing: inherit;
    }
    *:before, *:after {
      box-sizing: inherit;
    }

    body {
      min-height: 100vh;
      display: flex;
      font-family: "Inter", Arial;
      justify-content: center;
      align-items: center;
      background: #000;
    }
    body .dribbble {
      position: fixed;
      display: block;
      right: 20px;
      bottom: 20px;
    }
    body .dribbble img {
      display: block;
      height: 28px;
    }
    body .twitter {
      position: fixed;
      display: block;
      right: 64px;
      bottom: 14px;
    }
    body .twitter svg {
      width: 32px;
      height: 32px;
      fill: #1da1f2;
    }
  </style>
</head>
<body>
<button class="add-to-cart">
  <div class="cart">
    <svg viewBox="0 0 24 19">
      <path d="M11.25 17C11.25 17.6904 10.6904 18.25 10 18.25C9.30964 18.25 8.75 17.6904 8.75 17C8.75 16.3096 9.30964 15.75 10 15.75C10.6904 15.75 11.25 16.3096 11.25 17Z" stroke-width="1.5 "/>
      <path d="M19.25 17C19.25 17.6904 18.6904 18.25 18 18.25C17.3096 18.25 16.75 17.6904 16.75 17C16.75 16.3096 17.3096 15.75 18 15.75C18.6904 15.75 19.25 16.3096 19.25 17Z" stroke-width="1.5 "/>
      <path d="M1 1H5L5.91304 4M5.91304 4L8.06853 11.0823C8.32483 11.9245 9.10161 12.5 9.98188 12.5H18.585C19.4329 12.5 20.1887 11.9653 20.471 11.1656L23 4H5.91304Z" stroke-width="2" />
    </svg>
    <img srcset="https://assets.codepen.io/165585/alge.png 1x, https://assets.codepen.io/165585/alge@2x.png 2x" />
  </div>
  <span>Add to cart</span>
  <div class="check">
    <svg viewBox="0 0 10 10">
      <path d="M2 5L4 7L8 3" />
    </svg>
  </div>
  <svg class="background" viewBox="0 0 142 46">
    <path d="M0 19C0 10.7157 6.71573 4 15 4H41.4599C53.6032 4 62.4844 4 72.5547 4C82.6251 4 91.5063 4 103.65 4H137C139.761 4 142 6.23858 142 9V31C142 39.2843 135.284 46 127 46H5C2.23858 46 0 43.7614 0 41V19Z" />
  </svg>
</button>


<a class="dribbble" href="https://dribbble.com/ai" target="_blank"><img src="https://cdn.dribbble.com/assets/dribbble-ball-mark-2bd45f09c2fb58dbbfb44766d5d1d07c5a12972d602ef8b32204d28fa3dda554.svg" alt=""></a>
</body>

<script>
  const { to, registerPlugin, set, timeline } = gsap

  gsap.registerPlugin(MorphSVGPlugin, Physics2DPlugin)

  document.querySelectorAll('.add-to-cart').forEach(button => {
    let background = button.querySelector('.background path')
    button.addEventListener('pointerdown', e => {
      if(button.classList.contains('active')) {
        return
      }
      to(button, {
        '--background-s': .97,
        duration: .1
      })
    })
    button.addEventListener('click', e => {
      e.preventDefault()
      if(button.classList.contains('active')) {
        return
      }
      button.classList.add('active')
      to(button, {
        keyframes: [{
          '--background-s': .97,
          duration: .1
        }, {
          '--background-s': 1,
          delay: .1,
          duration: .8,
          ease: 'elastic.out(1, .6)'
        }]
      })
      to(button, {
        '--text-x': '16px',
        '--text-o': 0,
        duration: .2
      })
      to(button, {
        keyframes: [{
          '--cart-x': '-12px',
          '--cart-s': 1,
          duration: .25
        }, {
          '--bottle-s': 1,
          '--bottle-o': 1,
          duration: .15,
          onStart() {
            to(button, {
              duration: .4,
              keyframes: [{
                '--bottle-r': '-8deg'
              }, {
                '--bottle-r': '8deg'
              }, {
                '--bottle-r': '0deg'
              }]
            })
          }
        }, {
          '--bottle-y': '0px',
          duration: .3,
          delay: .15,
          onStart() {
            to(background, {
              keyframes: [{
                morphSVG: 'M0 19C0 10.7157 6.71573 4 15 4H41.4599C53.6032 4 62.4844 12 72.5547 12C82.6251 12 91.5063 4 103.65 4H137C139.761 4 142 6.23858 142 9V31C142 39.2843 135.284 46 127 46H5C2.23858 46 0 43.7614 0 41V19Z',
                duration: .1,
                delay: .18
              }, {
                morphSVG: 'M0 19C0 10.7157 6.71573 4 15 4H41.4599C53.6032 4 62.4844 4 72.5547 4C82.6251 4 91.5063 4 103.65 4H137C139.761 4 142 6.23858 142 9V31C142 39.2843 135.284 46 127 46H5C2.23858 46 0 43.7614 0 41V19Z',
                duration: .8,
                ease: 'elastic.out(1, .6)'
              }]
            })
            to(button, {
              '--bottle-s': .5,
              duration: .15
            })
          }
        }, {
          '--cart-y': '3px',
          duration: .1,
          onStart() {
            to(button, {
              keyframes: [{
                '--check-y': '24px',
                '--check-s': 1,
                duration: .25
              }, {
                '--check-offset': '0px',
                duration: .25
              }]
            })
          }
        }, {
          '--cart-y': '0px',
          duration: .2
        }, {
          '--cart-x': '-6px',
          '--bottle-r': '12deg',
          '--bottle-x': '-25%',
          duration: .15
        }, {
          '--cart-x': '-16px',
          '--bottle-r': '-12deg',
          '--bottle-x': '-50%',
          duration: .2,
          onStart() {
            drops(button, 5, -130, -100);
          },
        }, {
          '--cart-x': '92px',
          '--cart-r': '-20deg',
          duration: .4,
          onStart() {
            button.classList.add('clipped')
          },
          onComplete() {
            set(button, {
              '--cart-x': '-120px',
              '--cart-s': .8,
              '--cart-y': '-2px',
              '--bottle-o': 0,
              '--text-x': '2px'
            })
          }
        }, {
          '--cart-x': '-57px',
          '--cart-r': '0deg',
          '--check-s': 0,
          duration: .3,
          delay: .1,
          clearProps: true,
          onStart() {
            to(button, {
              '--text-x': '10px',
              '--text-o': 1,
              duration: .2,
              delay: .1
            })
          },
          onComplete() {
            button.classList.remove('active', 'clipped')
          }
        }]
      })
    })
  })

  function drops(parent, quantity, minAngle, maxAngle) {
    for(let i = quantity - 1; i >= 0; i--) {
      let angle = gsap.utils.random(minAngle, maxAngle),
              velocity = gsap.utils.random(60, 80)

      let div = document.createElement('div')
      div.classList.add('drop')

      parent.appendChild(div);

      set(div, {
        opacity: 1,
        scale: 0,
      });
      timeline({
        onComplete() {
          div.remove();
        }
      }).to(div, {
        duration: .4,
        scale: gsap.utils.random(.5, .7)
      }, 0).to(div, {
        duration: 1,
        physics2D: {
          angle: angle,
          velocity: velocity,
          gravity: 80
        }
      }, 0).to(div, {
        duration: .3,
        opacity: 0
      }, .3);
    }
  }

</script>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/625567.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

002Mybatis初始化引入

引入依赖 <dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId> </dependency> 自动检测工程中的DataSource创建并注册SqlSessionFactory实例创建并注册SqlSessionTemplate实例自…

chatgpt赋能python:Python中如何输入一个列表?

Python中如何输入一个列表&#xff1f; 如果你正在使用Python编程语言&#xff0c;那么输入一个列表是很常见的任务。列表是Python中最常用的数据类型之一&#xff0c;它允许我们在一个变量中存储多个值。在这篇文章中&#xff0c;我们将介绍如何使用Python语言输入一个列表&a…

chatgpt赋能python:Python中的16进制输出:从基础到应用

Python中的16进制输出&#xff1a;从基础到应用 在计算机编程中&#xff0c;16进制是一种非常重要的数字系统。对于Python工程师来说&#xff0c;熟练地掌握16进制输出技能非常重要&#xff0c;因为它能够帮助你更好地理解和分析二进制数据。 在本篇文章中&#xff0c;我们将…

JavaSE-03 【流程控制语句】

第一章 流程控制 1.1 流程概述 在一个程序执行的过程中&#xff0c;每条语句的执行顺序对程序的结果是由直接影响的&#xff0c; 也就是&#xff0c;语句的流程对运行结果有着直接的影响&#xff0c;所以&#xff0c;必须清楚知道每条语句的执行流程&#xff0c; 并且&#x…

Gossip分布式通信协议副本管理器说明

Gossip中副本管理器 副本管理器状态 不考虑应用时一个副本管理器应该有的状态&#xff1a; 值&#xff0c;这是由副本管理器维护的应用状态的值&#xff0c;每个副本管理器是一个状态机。起始于一个特定的初始值。此后的状态完全由更新操作决定。值的时间戳&#xff1a;代表更…

chatgpt赋能python:Python的包管理器-pip

Python的包管理器 - pip 什么是pip? pip是Python中的一个包管理工具&#xff0c;它可以用来安装、升级以及管理Python语言中的第三方模块。 如何安装pip 在Python 2.7.9和Python 3.4中&#xff0c;pip已经随着Python自带安装了。 如果你的Python没有安装pip&#xff0c;可…

JavaSSM笔记(四)

MySQL高级 在JavaWeb阶段&#xff0c;我们初步认识了MySQL数据库&#xff0c;包括一些基本操作&#xff0c;比如创建数据库、表、触发器&#xff0c;以及最基本的增删改查、事务等操作。而在此阶段&#xff0c;我们将继续深入学习MySQL&#xff0c;了解它的更多高级玩法&#…

JavaSSM笔记(三)

SpringSecurity 本章我们会一边讲解SpringSecurity框架&#xff0c;一边从头开始编写图书管理系统。 SpringSecurity是一个基于Spring开发的非常强大的权限验证框架&#xff0c;其核心功能包括&#xff1a; 认证 &#xff08;用户登录&#xff09;授权 &#xff08;此用户能…

【From Audio to Talking Heads in Real-Time with AI! RAD-NeRF explained】

视频链接&#xff1a;RAD-NeRF https://me.kiui.moe/radnerf/videos/obama_intro.mp4 From Audio to Talking Heads in Real-Time with AI! RAD-NeRF explained Efficient NeRFs for Real-Time Portrait Synthesis (RAD-NeRF) We’ve heard of deepfakes, we’ve heard of N…

Nacos架构与原理 - 配置模型

文章目录 背景概念介绍配置(Configuration)配置管理 (Configuration Management)配置服务 (Configuration Service)配置项&#xff08;Configuration Item&#xff09;配置集&#xff08;Configuration Set&#xff09;命名空间&#xff08;Namespace&#xff09;配置组&#x…

chatgpt赋能python:Python中如何实现print不换行

Python中如何实现print不换行 在编写Python程序时&#xff0c;我们经常需要使用print语句来输出信息。然而&#xff0c;有时候我们希望在输出信息时不换行&#xff0c;而是将多个输出信息打印在同一行上。这里介绍几种Python中print不换行的方式。 方法一&#xff1a;使用逗号…

Redis7分布式缓存

Redis7分布式缓存 一、Redis入门概述1.主流功能与应用2.命名规则 二、Redis 10 大数据类型1.redis字符串 (String)2. redis列表 (List)3. redis哈希表 (Hash)4. redis集合 (Set)5. redis有序集合 (ZSet)6. redis地理空间(GEO)7. redis基数统计 (HyperLogLog)8. redis位图 (bitm…

wavemlp怎么运行的

1.首先&#xff0c;输入进来的x是batchsize&#xff0c;64&#xff0c;256&#xff0c;256尺寸的。 他会用四个不同的conv组合&#xff0c;theta组合是由二维卷积&#xff08;batchnorm和relu的&#xff09;&#xff0c;得到两个值。 而&#xff0c;x_h和x_w都是通过一个简单…

JavaSE笔记(四)重制版

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eFLuY3vJ-1685927553034)(https://s2.loli.net/2022/09/22/lmKBNFc5wPEgjaS.png)] 面向对象高级篇 经过前面的学习&#xff0c;我们已经了解了面向对象编程的大部分基础内容&#xff0c;这一部分&…

一种新颖的智能优化算法—海鸥优化(SOA)算法

目录 一、SOA理论基础 二、ACO数学模型 2.1 迁徙 2.2 攻击 三、SOA伪代码 四、SOA运行结果 海鸥优化算法(Seagull Optimization Algorithm, SOA)是在2019年由 Dhiman 提出的一种受自然界海鸥启发的新颖全局优化算法&#xff0c;模拟了海鸥群体的迁徙和攻击行为。 一、SOA…

chatgpt赋能python:Python中如何实现1到100的循环?

Python中如何实现1到100的循环&#xff1f; 在Python中&#xff0c;实现1到100的循环非常简单。我们可以通过for循环、while循环和列表生成式来实现这个任务。 1. 使用for循环实现1到100的循环 使用for循环可以让我们轻松地遍历从1到100的整数。这种方法很适合在循环中需要进…

chatgpt赋能python:Python中的UTF-8

Python中的UTF-8 什么是UTF-8&#xff1f; 在开始介绍Python中的UTF-8&#xff0c;让我们先了解什么是UTF-8。UTF-8是一种Unicode字符集的编码方法&#xff0c;可以表示全球范围内的字符集&#xff0c;包括机器语言和人类语言。 Python和UTF-8 Python是一种高级编程语言&am…

工作基础知识

fpga 什么是fpga FPGA 是一种硬件可重构的体系结构。它的英文全称是Field Programmable Gate Array&#xff0c;中文名是现场可编程门阵列。 FPGA就是一个可以通过编程来改变内部结构的芯片。 FPGA 是在硅片上预先设计实现的具有可编程特性的集成电路&#xff0c;它能够按照…

完全卸载mysql教程

引言 很多人因为第一次安装mysql导致安装错误&#xff0c;或者安装的数据库版本太高&#xff0c;比如mysql8.0版本&#xff0c;出现了很多问题&#xff0c;导致数据库无法使用&#xff0c;或者一些图形界面无法操作&#xff0c;想要卸载&#xff0c;重装稳定的mysql数据库&…

一种新型智能优化算法—平衡优化算法(EO)

目录 一、EO理论基础 二、EO数学模型 2.1 种群初始化 2.2 建立平衡状态池 2.3 指数项 2.4 生成速率 2.5 更新解 三、EO流程图 四、EO运行结果 平衡优化器(Equilibrium Optimizer&#xff0c;EO)。该算法由Afshin Faramarzi等人于2020年提出的一种新型元启发式优…