如何使用纯CSS实现万圣节的toggle控件(附源码)

本篇文章给大家带来的内容是关于如何使用纯css实现万圣节的toggle控件(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

3690678522-5bcb42a45c729_articlex.gif

源代码地址

https://github.com/shanyuhai123/learnCSS/tree/master/0159-halloween-switcher

代码解读

定义容器 halloween-switcher , 通过 checkbox 来实现切换

引入字体, 居中显示:

立即学习“前端免费学习笔记(深入)”;

@import url('https://fonts.googleapis.com/css?family=Kodchasan');* {  font-family: 'Kodchasan';}html {  font-size: 20px;}body {  width: 100vw;  height: 100vh;  display: flex;  align-items: center;  justify-content: center;  background: #081219;  overflow: hidden;}

设置实际容器 label 大小

.halloween-label {  width: 30rem;  height: 10rem;  border: 3px solid #E56D48;  border-radius: 10rem;  cursor: pointer;  display: flex;  align-items: center;  position: relative;}

增加两种容器的配色

html {  --pumpkin-color: #E56D48;  --vampire-color: #4D7C99;}

定义 pumpkin-container , vampire-container 容器 及 文字

.halloween-input ~ .halloween-label::before,.halloween-input:checked ~ .halloween-label::before {  position: absolute;  font-size: 2.5rem;  text-transform: uppercase;}.halloween-input ~ .halloween-label::before {  content: 'Pumpkin';  color: var(--pumpkin-color);  left: 70%;  transform: translateX(-70%);}.halloween-input:checked ~ .halloween-label::before {  content: 'Vampire';  color: var(--vampire-color);  left: 25%;  transform: translateX(-25%);}.halloween-input ~ .halloween-label .pumpkin-container,.halloween-input ~ .halloween-label .vampire-container {  width: 9.5rem;  height: 9.5rem;  border-radius: 50%;  position: absolute;  left: 0.25rem;  overflow: hidden;}.halloween-input ~ .halloween-label .pumpkin-container {  background-color: var(--pumpkin-color);  filter: opacity(1);}.halloween-input ~ .halloween-label .vampire-container {  background-color: var(--vampire-color);  filter: opacity(0);}.halloween-input:checked ~ .halloween-label .pumpkin-container {  left: calc(100% - 0.25rem);  transform: translateX(-100%);  filter: opacity(0);}.halloween-input:checked ~ .halloween-label .vampire-container {  left: calc(100% - 0.25rem);  transform: translateX(-100%);  filter: opacity(1);}

增加 label容器 颜色渐变

.halloween-label {  border: 3px solid var(--label-border-color);  transition: .5s ease-in-out;}.halloween-label {  --label-border-color: var(--pumpkin-color);}.halloween-input:checked ~ .halloween-label {  --label-border-color: var(--vampire-color);}

pumpkin-container , vampire-container 容器 及 文字

动画效果

.halloween-input ~ .halloween-label::before,.halloween-input:checked ~ .halloween-label::before {  transition: .5s ease;}.halloween-input ~ .halloween-label .pumpkin-container,.halloween-input ~ .halloween-label .vampire-container {  transition: .5s ease;}

先绘画 pumpkin , 补全 pumpkin-container

新增果肉颜色

html {  --pumkin-pulp-color: #330A0F;}

绘画 pumpkinpumpkin__eyes-n-nose

伪元素画出眼睛

.pumpkin__eyes-n-nose {  position: absolute;  top: 20%;  width: 0;  height: 0;  border-style: solid;  border-width: 0 0.8rem 1.6rem 0.8rem;  color: var(--pumpkin-color);  border-bottom-color: var(--pumkin-pulp-color);  background-color: var(--pumkin-pulp-color);}.pumpkin__eyes-n-nose::before,.pumpkin__eyes-n-nose::after {  content: '';  position: absolute;  width: 1rem;  height: 1rem;  background-color: var(--pumkin-pulp-color);  border-radius: 50%;  top: 0.5rem;  left: 0;}.pumpkin__eyes-n-nose::before {  margin-left: -3.25rem;}.pumpkin__eyes-n-nose::after {  margin-left: 2.25rem;}

绘画 pumpkinpumpkin__mouth-n-teeths

伪元素画出牙齿

.pumpkin__mouth-n-teeths {  position: absolute;  width: 6.5rem;  height: 3.25rem;  bottom: 10%;  background-color: var(--pumkin-pulp-color);  border-radius: 0 0 6.5rem 6.5rem;}.pumpkin__mouth-n-teeths::before,.pumpkin__mouth-n-teeths::after {  content: '';  position: absolute;  height: 0.75rem;  width: 1rem;  background-color: var(--pumpkin-color);}.pumpkin__mouth-n-teeths::before {  top: 0;  left: 1.25rem;}.pumpkin__mouth-n-teeths::after {  height: 1rem;  bottom: 0;  right: 1.25rem;}

再绘画 vampire , 补全 vampire-container

利用 伪元素 绘出 vampire-container 的脸

.vampire-container::before,.vampire-container::after {  content: '';  position: absolute;  width: 100%;  height: 100%;  background-color: #c2def2;  /* face color */  border-radius: 45% 45% 0 0;  top: 0.75rem;}.vampire-container::before {  left: -4rem;}.vampire-container::after {  right: -4rem;}

伪元素绘出 vampire__eyes

.vampire__eyes {  top: 20%;  position: absolute;  z-index: 1;}.vampire__eyes::before,.vampire__eyes::after {  content: '';  position: absolute;  width: 1rem;  height: 1rem;  background-color: #d63e49; /* eye-color */  border-radius: 50%;  top: 0.5rem;  left: 0;}.vampire__eyes::before {  margin-left: -3.25rem;}.vampire__eyes::after {  margin-left: 2.25rem;}

绘出 vampire__mouth

.vampire__mouth {  position: absolute;  width: 6.5rem;  height: 3.25rem;  background-color: var(--pumkin-pulp-color);  bottom: 10%;  border-radius: 0 0 6.5rem 6.5rem;  display: flex;  justify-content: center;  overflow: hidden;  z-index: 1;}

绘出 vampire__teeths 门牙, 伪元素绘出牙齿

.vampire__teeths {  position: absolute;  width: 100%;  height: 1rem;  background-color: #fffae6;  top: -1px;}.vampire__teeths::before,.vampire__teeths::after {  content: '';  position: absolute;  width: 0;  height: 0;  color: transparent;  border-style: solid;  border-width: 0.65rem 0.375rem 0 0.375rem;  border-top-color: #fffae6;  top: 0.95rem;}.vampire__teeths::before {  left: 1rem;}.vampire__teeths::after {  right: 1rem;}

绘出 vampire__tongue

.vampire__tongue {  position: absolute;  width: 3.5rem;  height: 1.75rem;  background-color: #d63e49;  bottom: -0.75rem;  border-radius: 3.5rem 3.5rem 0 0;}

再接着把 checkbox 隐藏掉即可

.halloween-input {  display: none;}

增加微笑动画 smile

.vampire__teeths {  animation: smile 2s ease-in-out infinite;}.vampire__tongue {  animation: smile 3s ease-in-out infinite;}@keyframes smile {  50% {    transform: scaleY(1.5);  }}

以上就是如何使用纯CSS实现万圣节的toggle控件(附源码)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1612702.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 03:07:31
下一篇 2025年12月24日 03:08:01

相关推荐

  • 如何使用CSS和Vanilla.js实现展示苹果设备的交互动画(附源码)

    本篇文章给大家带来的内容是关于如何用css和vanilla.js实现展示苹果设备的交互动画(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代…

    2025年12月24日
    000
  • CSS 3D实现旋转球是如何实现的?(代码案例)

    本篇文章给大家带来的内容是关于css 3d实现旋转球是如何实现的?(代码案例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 废话不多说了,直接给大家贴代码了,具体代码如下所示: zimv-css 3d ballbody{padding: 100px 0 0 150px;}.wra…

    2025年12月24日
    000
  • css1 css2 css3 区别有哪些?区别详解

    本篇文章给大家带来的内容是关于css1 css2 css3 区别有哪些?区别详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 CSS1提供有关字体、颜色、位置和文本属性的基本信息,该版本已经得到了目前解析HTML和XML的浏览器的广泛支持。 但自从CSS1的版本之后,又在1998…

    2025年12月24日
    000
  • 图文详解CSS中rgba,rgb和opacity之间的区别

    css中设置背景颜色的方式有很多,比如background-color,rgb,rgba等等,那你知道rgba,rgb和opacity之间的区别吗?这篇文章就给大家讲讲rgba,rgb和opacity之间的区别,有一定的参考价值,感兴趣的朋友可以参考一下。 rgb和rgba的区别: rgb就是指红色…

    2025年12月24日
    000
  • CSS实现富有创意的页面加载(loading)动画效果

    小伙伴们在浏览网站时有没有遇到页面“loading中,请稍后”的情况,作为前端工程师,你会用css制作页面加载(loading)动画效果吗?这篇文章给大家分享一个富有创意的页面加载(loading)动画代码,有一定的参考价值,感兴趣的朋友可以看看。 制作一个富有创意的页面加载(loading)动画需…

    2025年12月24日
    000
  • 什么是BFC?BFC的深入解析

    本篇文章给大家带来的内容是关于什么是bfc?bfc的深入解析 ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、什么是BFC Formatting context 是 W3C CSS2.1 规范中的一个概念。它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素将如何定位…

    2025年12月24日 好文分享
    000
  • css3中all属性有什么用?css3中all属性的用法介绍

    本篇文章给大家带来的内容是关于css3中all属性有什么用?css3中all属性的用法介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 一、兼容性 如下图: 兼容性还行, 除了IE不支持,其他浏览器基本上都绿油油,目前自娱自乐,内网项目什么的都是可以用用的。 二、all是干嘛用的…

    2025年12月24日 好文分享
    000
  • css中flex弹性布局的步骤讲解(附代码)

    本篇文章给大家带来的内容是关于css中flex弹性布局的步骤讲解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 html: *{ margin: 0; padding: 0; box-sizing: border-box; } .wrap{ width: 300px; h…

    2025年12月24日 好文分享
    000
  • css中clip-path属性的用法讲解(附代码)

    本篇文章给大家带来的内容是关于css中clip-path属性的用法讲解(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 clip-path的使用 polygon 值为多个坐标点组成,坐标第一个值是x方向,第二个值是y方向。 左上角为原点,右下角是(100%,100%)的点。…

    2025年12月24日 好文分享
    000
  • HTML+CSS实现好看的三角形提示框样式

    在浏览网站时,大家有没有发现网站中有各式各样新颖的提示框,那你知道这些好看的提示框怎么制作的吗?这篇文章就和大家分享一个css实现的好看的三角形提示框,有一定的参考价值,感兴趣的朋友可以参考一下。 想要用CSS实现三角形提示框样式需要用到很多CSS中的属性,比如:display属性,border-r…

    2025年12月24日
    000
  • CSS中Overflow的属性是什么?Overflow属性详解

    很多人学习css的时候,不太知道overflow的属性是什么?怎么用overflow的属性,下面创想鸟为你总结一下overflow属性和用法。 我们都知道,盒子的大小和盒子的位置都是可以用css来控制的,但是有些时候,我们的盒子出现内外都改变的时候,css将如何处理呢,假如,我们设置盒子的高度,我们…

    2025年12月24日
    000
  • css怎么让背景图片居中?背景图片居中的方法介绍(代码实例)

    在前端页面的开发中,图片的显示方法有两种,分别为:img标签显示图片,background属性设置为背景图片显示。我们知道img图片可以设置图片居中效果,那么背景图片可以设置居中吗?如何让背景图片居中?本篇文章就给大家介绍css实现背景图片的居中的方法。有一定的参考价值,有需要的朋友可以参考一下,希…

    2025年12月24日
    000
  • HTML+CSS实现页面加载(loading)动画效果

    大家在浏览页面时有没有遇到页面正在loading(加载)的情况,那作为一个前端开发人员,你知道如何用css3和html制作页面加载动画效果吗?这篇文章就和大家分享一个超级简单实用的css3 圆圈加载(loading)动画效果的代码,有一定的参考价值,感兴趣的朋友可以看看。 想要实现loading加载…

    2025年12月24日
    000
  • 浅谈css使用hsl()和hsla()设置颜色值的方法(图文详解)

    css如何使用hsl()和hsla()设置颜色值?本篇文章就给大家浅谈一下css使用hsl()和hsla()设置颜色值的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 css中的两种设置颜色值的方式:hsl()和hsla(),它们基本上都是采用了HSL色彩模式的方法来设置颜色…

    2025年12月24日 好文分享
    000
  • 如何使用纯CSS实现棋盘的错觉动画(附源码)

    本篇文章给大家带来的内容是关于如何使用纯css实现棋盘的错觉动画(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 https://github.com/comehope/front-end-daily-challenges 代码解读 定义 dom,容器…

    2025年12月24日
    000
  • flex多列布局有哪些?flex四种多列布局的介绍

    本篇文章给大家带来的内容是关于flex多列布局有哪些?flex四种多列布局的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 基本的等分三列布局 .container{ display: flex; width: 500px; height: 200px; } .left{ fl…

    2025年12月24日 好文分享
    000
  • css3学习之flex实现几种多列布局

    本篇文章就给大家介绍css3学习之flex实现几种多列布局的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 基本的等分三列布局 .container{ display: flex; width: 500px; height: 200px; } .left{ flex:1; b…

    2025年12月24日 好文分享
    000
  • css实现两边固定中间自适应布局的四种常用方法

    本篇文章给大家带来的内容是关于css实现两边固定中间自适应布局的四种常用方法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 解析四种常用方法以及原理:浮动、浮动内嵌 div、定位、flex。 浮动 .wrap {background: #eee; padding: 20px; } …

    2025年12月24日
    000
  • css中垂直水平居中的实现方法总结(附代码)

    本篇文章给大家带来的内容是关于css中垂直水平居中的实现方法总结(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 最近看到很多面试题目会问:请说出几种使用css完成垂直水平居中的方法?正好看css基础的时候看到一篇文章是讲完全居中的,这边对于文章中的内容做个小结 一、使用a…

    2025年12月24日 好文分享
    000
  • vue数据动态添加和动态绑定思路(图文)

    本篇文章给大家带来的内容是关于vue数据动态添加和动态绑定思路(图文),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 先上案例 首先来分析一下,勾选科目的时候,下面同时增加科目的满分值设置。 以前写jquery的思路:当勾选的时候创建dom节点,然后把dom节点append到父节点…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信