25 心形按钮

效果演示

14-心形按钮.gif

实现了一个心形的心形图案,当用户点击图案时,图案会旋转并缩小,同时背景颜色会变成白色。

Code

<div class="love"><input id="switch" type="checkbox"><label class="love-heart" for="switch"><i class="left"></i><i class="right"></i><i class="bottom"></i><div class="round"></div></label>
</div>
body {height: 100vh;display: flex;justify-content: center;align-items: center;background-color: #212121;
}.love-heart:before,
#switch {display: none;
}.love-heart,
.love-heart::after {border-color: hsl(231deg 28% 86%);border: 1px solid;border-top-left-radius: 100px;border-top-right-radius: 100px;width: 10px;height: 8px;border-bottom: 0
}.round {position: absolute;z-index: 1;width: 8px;height: 8px;background: hsl(0deg 0% 100%);box-shadow: rgb(0 0 0 / 24%) 0px 0px 4px 0px;border-radius: 100%;left: 0px;bottom: -1px;transition: all .5s ease;animation: check-animation2 .5s forwards;
}input:checked+label .round {transform: translate(0px, 0px);animation: check-animation .5s forwards;background-color: hsl(0deg 0% 100%);
}@keyframes check-animation {0% {transform: translate(0px, 0px);}50% {transform: translate(0px, 7px);}100% {transform: translate(7px, 7px);}
}@keyframes check-animation2 {0% {transform: translate(7px, 7px);}50% {transform: translate(0px, 7px);}100% {transform: translate(0px, 0px);}
}.love-heart {box-sizing: border-box;position: relative;transform: rotate(-45deg) translate(-50%, -33px) scale(4);display: block;border-color: hsl(231deg 28% 86%);cursor: pointer;top: 0;
}input:checked+.love-heart,
input:checked+.love-heart::after,
input:checked+.love-heart .bottom {border-color: hsl(347deg 81% 61%);box-shadow: inset 6px -5px 0px 2px hsl(347deg 99% 72%);
}.love-heart::after,
.love-heart .bottom {content: "";display: block;box-sizing: border-box;position: absolute;border-color: hsl(231deg 28% 86%);
}.love-heart::after {right: -9px;transform: rotate(90deg);top: 7px;
}.love-heart .bottom {width: 11px;height: 11px;border-left: 1px solid;border-bottom: 1px solid;border-color: hsl(231deg 28% 86%);left: -1px;top: 5px;border-radius: 0px 0px 0px 5px;
}

实现思路拆分

cbody {height: 100vh; /* 设置页面高度为视口高度 */display: flex; /* 设置页面布局为弹性布局 */justify-content: center; /* 设置主轴对齐方式为居中对齐 */align-items: center; /* 设置交叉轴对齐方式为居中对齐 */background-color: #212121; /* 设置背景颜色为深灰色 */
}

这段代码设置了页面的基本样式,包括高度、布局、对齐方式和背景颜色。

.love-heart:before,
#switch {display: none; /* 隐藏元素 */
}

这段代码隐藏了 .love-heart:before#switch 两个元素。

.love-heart,
.love-heart::after {border-color: hsl(231deg 28% 86%); /* 设置边框颜色为深黄色 */border: 1px solid; /* 设置边框为实线 */border-top-left-radius: 100px; /* 设置左上角圆角半径为 100px */border-top-right-radius: 100px; /* 设置右上角圆角半径为 100px */width: 10px; /* 设置宽度为 10px */height: 8px; /* 设置高度为 8px */border-bottom: 0 /* 隐藏底部边框 */
}

这段代码设置了 .love-heart.love-heart::after 两个元素的样式,包括边框颜色、边框、圆角半径、宽度、高度和底部边框。

.round {position: absolute; /* 设置元素的定位方式为绝对定位 */z-index: 1; /* 设置元素的堆叠顺序为最高 */width: 8px; /* 设置元素的宽度为 8px */height: 8px; /* 设置元素的高度为 8px */background: hsl(0deg 0% 100%); /* 设置元素的背景颜色为白色 */box-shadow: rgb(0 0 0 / 24%) 0px 0px 4px 0px; /* 设置元素的阴影效果 */border-radius: 100%; /* 设置元素的圆角半径为 100% */left: 0px; /* 设置元素的左边距为 0px */bottom: -1px; /* 设置元素的底部边距为 -1px */transition: all.5s ease; /* 设置元素的过渡效果 */animation: check-animation2.5s forwards; /* 设置元素的动画效果 */
}

这段代码设置了 .round 元素的样式,包括定位方式、堆叠顺序、宽度、高度、背景颜色、阴影效果、圆角半径、左边距、底部边距、过渡效果和动画效果。

input:checked+label.round {transform: translate(0px, 0px); /* 移动元素 */animation: check-animation.5s forwards; /* 执行动画 */background-color: hsl(0deg 0% 100%); /* 设置背景颜色为白色 */
}

这段代码设置了 :checked 状态下的 .round 元素的样式,包括移动元素、执行动画和背景颜色。

@keyframes check-animation {0% {transform: translate(0px, 0px); /* 元素初始状态 */}50% {transform: translate(0px, 7px); /* 元素动画过程 */}100% {transform: translate(7px, 7px); /* 元素最终状态 */}
}

这段代码定义了一个名为 check-animation 的动画效果,包括元素的初始状态、动画过程和最终状态。

.love-heart {box-sizing: border-box; /* 设置盒模型为 border-box */position: relative; /* 设置定位为相对定位 */transform: rotate(-45deg) translate(-50%, -33px) scale(4); /* 旋转 -45 度,平移 -50% -33px,缩放 4 倍 */display: block; /* 设置显示为块级元素 */border-color: hsl(231deg 28% 86%); /* 边框颜色 */cursor: pointer; /* 光标类型为指针 */top: 0; /* 上侧偏移量为 0 */
}

这段代码设置了 .love-heart 元素的样式,包括盒模型、定位、旋转、缩放、显示、边框颜色、光标类型和上侧偏移量。

input:checked+.love-heart,
input:checked+.love-heart::after,
input:checked+.love-heart.bottom {border-color: hsl(347deg 81% 61%); /* 边框颜色 */box-shadow: inset 6px -5px 0px 2px hsl(347deg 99% 72%); /* 阴影效果 */
}

这段代码设置了 :checked 状态下的 .love-heart 元素和 .love-heart::after 元素的样式,包括边框颜色和阴影效果。

.love-heart::after,
.love-heart.bottom {content: ""; /* 内容为空 */display: block; /* 显示为块级元素 */box-sizing: border-box; /* 设置盒模型为 border-box */position: absolute; /* 定位为绝对定位 */border-color: hsl(231deg 28% 86%); /* 边框颜色 */
}

这段代码设置了 .love-heart::after.love-heart.bottom 元素的样式,包括内容、显示方式、盒模型、定位、边框颜色。

.love-heart::after {right: -9px; /* 右侧偏移量 */transform: rotate(90deg); /* 旋转 90 度 */top: 7px; /* 上侧偏移量 */
}

这段代码设置了 .love-heart::after 元素的样式,包括右侧偏移量、旋转角度和上侧偏移量。

.love-heart.bottom {width: 11px; /* 宽度为 11px */height: 11px; /* 高度为 11px */border-left: 1px solid; /* 左侧边框为实线 */border-bottom: 1px solid; /* 下侧边框为实线 */border-color: hsl(231deg 28% 86%); /* 边框颜色 */left: -1px; /* 左侧偏移量 */top: 5px; /* 上侧偏移量 */border-radius: 0px 0px 0px 5px; /* 左上角圆角半径为 0px,右上角圆角半径为 5px */
}

这段代码设置了 .love-heart.bottom 元素的样式,包括宽度、高度、左侧边框、下侧边框、边框颜色、左侧偏移量、上侧偏移量和圆角半径。

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

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

相关文章

049.Python包和模块_虚拟环境超详细讲解

我 的 个 人 主 页&#xff1a;&#x1f449;&#x1f449; 失心疯的个人主页 &#x1f448;&#x1f448; 入 门 教 程 推 荐 &#xff1a;&#x1f449;&#x1f449; Python零基础入门教程合集 &#x1f448;&#x1f448; 虚 拟 环 境 搭 建 &#xff1a;&#x1f449;&…

二叉树的层序遍历经典问题(算法村第六关白银挑战)

基本的层序遍历与变换 二叉树的层序遍历 102. 二叉树的层序遍历 - 力扣&#xff08;LeetCode&#xff09; 给你二叉树的根节点 root &#xff0c;返回其节点值的 层序遍历 。 &#xff08;即逐层地&#xff0c;从左到右访问所有节点&#xff09;。 示例 1&#xff1a; 输入…

Java顺序表(1)

&#x1f435;本篇文章将对顺序表中的方法进行模拟实现 一、线性表 线性表是指在逻辑结构上呈连续的线性结构&#xff0c;而在物理结构上不一定是连续的结构&#xff0c;常见的线性表有&#xff1a;顺序表、链表、栈、队列等 二、顺序表 顺序表一般采用数组来存储数据&#x…

【STM32】| 01——常用外设 | USART

系列文章目录 【STM32】| 01——常用外设 | USART 失败了也挺可爱&#xff0c;成功了就超帅。 文章目录 前言1. 基础理论1.1 并行通信和串行通信1.2 同步通信和异步通信1.3 单工/半双工/全双工1.4 电平信号(RS232/TTL)和差分信号(RS485)1.5 端口(COM) 2. 串口理论2.1 串口物理…

Springboot+RocketMQ通过事务消息优雅的实现订单支付功能

目录 1. 事务消息 1.1 RocketMQ事务消息的原理 1.2 RocketMQ订单支付功能设计 1. 事务消息 RocketMQ的事务消息&#xff0c;是指发送消息事件和其他事件需要同时成功或同时失败。比如银行转账&#xff0c; A银行的某账户要转一万元到B银行的某账户。A银行发送“B银行账户增加…

高级分布式系统-第3讲 网络与网络互联

万维网的诞生 1957年10月4日&#xff0c; 苏联发射了人类第一颗人造卫星—斯普特尼克一号 美国政府震惊不已。 他们认为&#xff0c; 在日趋激烈的冷战对抗中&#xff0c; 自己已经全面落后于苏联。 为了扭转这一局面&#xff0c; 美国国防部很快于1958 年 2 月组建了一个神秘…

Fastdata极数公司介绍

【写在开头】 前不久看到一句话和一个新闻&#xff0c;“数据作为主要生产要素&#xff0c;以资源化为起点&#xff0c;经历资产化、资本化阶段&#xff0c;逐步实现数据价值。” 2023年10月25日&#xff0c;国家数据局正式揭牌&#xff0c;由国家发展和改革委员会管理。 初看…

linux安装node.js

先去官网下载对应的版本 官网&#xff1a;https://nodejs.org/en/download 选择对应的版本&#xff0c;点这个&#xff0c;直接去虚拟机上面安装 # apt的系统 apt install -y wget # yum的系统 yum install -y wget下载包 wget https://nodejs.org/dist/v20.10.0/node-v20.…

【小白专用】(C#)用户、角色、权限控制体系

我们在开发很多项目的时候,都会用到用户权限管理,我也在很多项目里做过权限控制,所以,我也总结出一套条理清晰的角色权限控制体系。本文采用RBAC&#xff08;Role Based Access Control&#xff09;的基本思想&#xff0c;RBAC&#xff08;角色访问控制&#xff09;的基本思想可…

Java可视化大屏智慧工地云平台源码(SaaS模式)

智慧工地是一种崭新的工程现场一体化管理模式&#xff0c;是互联网与传统建筑行业的深度融合。它充分利用移动互联、物联网、云计算、大数据等新一代信息技术&#xff0c;围绕人、机、料、法、环等各方面关键因素&#xff0c;彻底改变传统建筑施工现场参建各方现场管理的交互方…

5G前装搭载率即将迈过10%大关,车载通讯进入多层次增长通道

对于智能化来说&#xff0c;车载通讯性能的提升&#xff0c;对于相关功能的用户体验优化、进一步减少通讯时延以及打开应用新空间&#xff0c;至关重要。 目前&#xff0c;2G/3G正在进入运营商逐步关闭运营的阶段&#xff0c;4G依然是主力&#xff0c;但5G也在迎来新的增长机会…

imazing破解版百度云2.17.3(附激活许可证下载)

iMazing是一款强大的 iOS 设备管理软件&#xff0c;不管是 iPhone、iPad 或 iPod Touch 设备&#xff0c;只要将 iOS 设备连接到计算机&#xff0c;就可以处理不同类型的数据。 iPhone 和 iPad 备份 借助 iMazing 的独有 iOS 备份技术&#xff08;无线、隐私和自动&#xff09…

强化学习的数学原理学习笔记 - 策略梯度(Policy Gradient)

文章目录 概览&#xff1a;RL方法分类策略梯度&#xff08;Policy Gradient&#xff09;Basic Policy Gradient目标函数1&#xff1a;平均状态值目标函数2&#xff1a;平均单步奖励&#x1f7e1;PG梯度计算 &#x1f7e6;REINFORCE 本系列文章介绍强化学习基础知识与经典算法原…

速卖通跨境智星:解决IP及环境问题,实现批量注册轻松搞定

如果想要注册大批量的速卖通买家号&#xff0c;关键问题之一就是IP及浏览环境的管理。为了确保每个账号都能独立运行&#xff0c;使用独立的IP是必不可少的。近期&#xff0c;速卖通跨境智星备受关注&#xff0c;支持绑定代理IP&#xff0c;并内置反指纹技术&#xff0c;为用户…

WinForms中的UI卡死

WinForms中的UI卡死 WinForms中的UI卡死通常是由于长时间运行的操作阻塞了UI线程所导致的。在UI线程上执行的操作&#xff0c;例如数据访问、计算、文件读写等&#xff0c;如果耗时较长&#xff0c;会使得UI界面失去响应&#xff0c;甚至出现卡死的情况。 解决方法 为了避免…

USACO(美国计算机竞赛)详细介绍 如何备赛 训练资料整理

竞赛简介&#xff1a; USACO&#xff08;美国信息学奥林匹克竞赛&#xff09;初次举办于1992年&#xff0c;其官网是美国一个著名在线题库&#xff0c;更是美国中学生的官方竞赛网站&#xff0c;开设目的是为每年夏季举办的国际信息学奥林匹克竞赛&#xff08;IOI&#xff09;…

深度学习——R-CNN目标检测原理

R-CNN系列算法需要先产生候选区域&#xff0c;再对候选区域做分类和位置坐标的预测&#xff0c;这类算法被称为两阶段目标检测算法。近几年&#xff0c;很多研究人员相继提出一系列单阶段的检测算法&#xff0c;只需要一个网络即可同时产生候选区域并预测出物体的类别和位置坐标…

开源C语言库Melon:I/O线程模型

本文展示开源C语言库Melon中的I/O线程模型。在Melon中存在三种线程模型&#xff0c;本篇仅对I/O线程模型进行说明。 关于 Melon 库&#xff0c;这是一个开源的 C 语言库&#xff0c;它具有&#xff1a;开箱即用、无第三方依赖、安装部署简单、中英文文档齐全等优势。 Github …

如何创建容器搭建节点

1.注册Discord账号 https://discord.com/这是登录网址&#xff1a; https://discord.com/ 2.点击startnow注册&#xff0c;用discord注册或者邮箱注册都可&#xff0c;然后登录tickhosting Tick Hosting这是登录网址&#xff1a;Tick Hosting 3.创建servers 4.点击你创建的s…

欧洲编程语言四巨头

从左往右&#xff0c;依次是 尼克劳斯沃斯 (Niklaus Wirth)&#xff0c;迪杰斯特拉&#xff08;Edsger Dijkstra&#xff09;&#xff0c;霍尔&#xff08;Tony Hoare&#xff09; 尼克劳斯沃斯 (Niklaus Wirth) 瑞士人&#xff0c;一生发明了8种编程语言&#xff0c;其中最著…