25 心形按钮

2024-01-09 08:04
文章标签 25 按钮 心形

本文主要是介绍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 元素的样式,包括宽度、高度、左侧边框、下侧边框、边框颜色、左侧偏移量、上侧偏移量和圆角半径。

这篇关于25 心形按钮的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/586446

相关文章

C# 防止按钮botton重复“点击”的方法

在使用C#的按钮控件的时候,经常我们想如果出现了多次点击的时候只让其在执行的时候只响应一次。这个时候很多人可能会想到使用Enable=false, 但是实际情况是还是会被多次触发,因为C#采用的是消息队列机制,这个时候我们只需要在Enable = true 之前加一句 Application.DoEvents();就能达到防止重复点击的问题。 private void btnGenerateSh

【JavaScript】LeetCode:21-25

文章目录 21 最大子数组和22 合并区间23 轮转数组24 除自身以外数组的乘积25 缺失的第一个正数 21 最大子数组和 贪心 / 动态规划贪心:连续和(count)< 0时,放弃当前起点的连续和,将下一个数作为新起点,这里提供使用贪心算法解决本题的代码。动态规划:dp[i]:以nums[i]为结尾的最长连续子序列(子数组)和。 dp[i] = max(dp[i - 1]

PNG透明背景按钮的实现(MFC)

问题描述: 当前要在对话框上添加一个以两个PNG图片作为背景的按钮,PNG图的背景是透明的,按钮也要做出相同的透明效果。并且鼠标不在按钮上时,按钮显示"bg1.png";鼠标移动到按钮上时,按钮显示"bg2.png" 开发环境为VS2010。 解决办法: 使用GDI+库装载PNG图片,并使用MFC Button Control和CMFCButton类结合,调用CMFCButton

龙芯+FreeRTOS+LVGL实战笔记(新)——05部署主按钮

本专栏是笔者另一个专栏《龙芯+RT-Thread+LVGL实战笔记》的姊妹篇,主要的区别在于实时操作系统的不同,章节的安排和任务的推进保持一致,并对源码做了改进和优化,各位可以先到本人主页下去浏览另一专栏的博客列表(目前已撰写36篇,图1所示),再决定是否订阅。此外,也可以前往本人在B站的视频合集(图2所示)观看所有演示视频,合集首个视频链接为: 借助RT-Thread和LVGL

2025年25届计算机毕业设计:如何实现高校实验室Java SpringBoot教学管理系统

✍✍计算机毕业编程指导师** ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java、Python、微信小程序、大数据实战项目集 ⚡⚡文末获取源码 文章目录 ⚡⚡文末获取源码高校实验室教学管理系统-研究背景高校实验室教学管理系

致远个性化之--发起流程页面,去掉【查看流程】按钮

需求 近期在做的项目中,遇到一个需求,想把发起流程页面中的【查看流程】按钮去掉,只让员工预测流程,知道自己的事项流程走向,不让看全局流程图。包含PC端和移动端,以及微协同端。 如下图效果示例: 实现 此需求,只能通过修改页面代码实现。在此不分析实现过程,现把具体实现方式呈现如下,各位如有需求可参照设置。适用版本V9.0,其他版本未进行测试,估计不会有大的差别! PC端 找到文件

智力题:25匹马5条跑道找最快的3匹马,最少需要跑几次?

要找出25匹马中最快的3匹马,使用5条跑道,最少需要跑几次?我们可以通过逐步推理来解决这个问题。 第一步:分组比赛 首先,我们将25匹马分成5组,每组5匹马。每组进行一次比赛,这样我们就有5次比赛的结果。 组1:A1, A2, A3, A4, A5 组2:B1, B2, B3, B4, B5 组3:C1, C2, C3, C4, C5 组4:D1, D2, D3, D4, D5 组

芬兰手游业25年发展史

自2010年Rovio凭借《愤怒的小鸟》成功以来,芬兰的优秀开发者可以说是不断的引领手游潮流,有Frogmid、Seriously这样的小型团队,也有Supercell这样的世界收入冠军。除却收入之外,我们可以发现芬兰开发商的手游绝大多数都是具有独特创意的。 为什么芬兰手游业可以具有如此之大的竞争优势?其他人想要赶上应该怎么做?这个答案从来都不是能够简单作答的,因为它根植于芬兰的行业发展史,所以

如何在Excel中创建一个VBA宏,并设置一个按钮来执行这个宏

下面是一个详细的步骤指南 步骤1:创建VBA宏 1. 打开Excel并按 `Alt + F11` 打开VBA编辑器。 2. 在VBA编辑器中,选择 `Insert` > `Module` 来插入一个新的模块。 3. 将以下代码粘贴到模块中: ```vba Sub CreateNewSheet()' 声明一个工作表对象Dim newSheet As Worksheet' 添加一个新的工作表S

Vue3实现点击按钮下载头像功能

要实现的效果 点击头像右上角弹出选项,点击保存图片可以把图片下载保存到本地 实现方式关键代码 1.第一种,直接创建a标签给头像地址。进行下载 // 创建一个隐藏的 <a> 标签const link = document.createElement("a");link.href = headPic; // 设置为图片的 URLlink.download = "avatar.jpg"; //