自定义开关(switch)

news/2025/1/10 21:46:29/文章来源:https://www.cnblogs.com/dkf717/p/18640802

演示代码

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>custom_switch</title></head><style>/** 开关 */.custom_switch {--switch-padding: 3px;--btnSize: 20px;--animation: all 0.3s;display: inline-flex;align-items: center;padding: var(--switch-padding);background-color: #ccc;color: #fff;border-radius: calc(var(--btnSize) + var(--switch-padding) * 2);cursor: pointer;user-select: none;font-family: Helvetica;line-height: var(--btnSize);transition: var(--animation);position: relative;padding-left: calc(var(--btnSize) + var(--switch-padding));}/** 开关-按钮 */.custom_switch::before {content: "";width: var(--btnSize);height: var(--btnSize);background-color: #fff;border-radius: 50%;position: absolute;left: var(--switch-padding);transition: var(--animation);}/** 开关-文本 */.custom_switch::after {content: attr(data-inactive);padding: 0 5px;}/** 开关-激活 */.custom_switch.active {background-color: #5a76ff;padding-left: var(--switch-padding);padding-right: calc(var(--btnSize) + var(--switch-padding));}/** 开关-激活-按钮 */.custom_switch.active::before {left: calc(100% - var(--btnSize) - var(--switch-padding));}/** 开关-激活-文本 */.custom_switch.active::after {content: attr(data-active);}</style><body><div class="custom_switch" data-active="启用" data-inactive="禁用"></div><div class="custom_switch active" data-active="启用" data-inactive="不启用"></div></body><script>document.querySelectorAll(".custom_switch").forEach((item) => {item.addEventListener("click", () => {item.classList.toggle("active");});});// }, 1000);</script>
</html>

纯净样式

/** 开关 */
.custom_switch {--switch-padding: 3px;--btnSize: 20px;--animation: all 0.3s;display: inline-flex;align-items: center;padding: var(--switch-padding);background-color: #ccc;color: #fff;border-radius: calc(var(--btnSize) + var(--switch-padding) * 2);cursor: pointer;user-select: none;font-family: Helvetica;line-height: var(--btnSize);transition: var(--animation);position: relative;padding-left: calc(var(--btnSize) + var(--switch-padding));
}
/** 开关-按钮 */
.custom_switch::before {content: "";width: var(--btnSize);height: var(--btnSize);background-color: #fff;border-radius: 50%;position: absolute;left: var(--switch-padding);transition: var(--animation);
}
/** 开关-文本 */
.custom_switch::after {content: attr(data-inactive);padding: 0 5px;
}
/** 开关-激活 */
.custom_switch.active {background-color: #5a76ff;padding-left: var(--switch-padding);padding-right: calc(var(--btnSize) + var(--switch-padding));
}
/** 开关-激活-按钮 */
.custom_switch.active::before {left: calc(100% - var(--btnSize) - var(--switch-padding));
}
/** 开关-激活-文本 */
.custom_switch.active::after {content: attr(data-active);
}

使用方法

<div class="custom_switch" data-active="启用" data-inactive="禁用"></div>
<div class="custom_switch active" data-active="启用" data-inactive="不启用"></div>
<!-- 
默认开关为关闭状态,通过切换class切换状态
class="active" 开关为开启状态
data-active="开启状态文本" 开关为开启状态时的文本
data-inactive="关闭状态文本" 开关为关闭状态时的文本-->

效果

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

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

相关文章

鸿蒙ArkUI-X简介

ArkUI是一套构建分布式应用的声明式UI开发框架。它具备简洁自然的UI信息语法、丰富的UI组件、多维的状态管理,以及实时界面预览等相关能力,帮助您提升应用开发效率,并能在多种设备上实现生动而流畅的用户体验。 ArkUI-X进一步将ArkUI扩展到了多个OS平台:目前支持OpenHarmon…

腾讯云 AI 代码助手:从 0 到 1 打造自己的专属产品网页

手把手教零基础前端小白运用腾讯云 AI 代码助手,从 0 到 1 打造自己的专属产品网页:手把手教零基础前端小白运用腾讯云 AI 代码助手,从 0 到 1 打造自己的专属产品网页: 安装腾讯云 AI 代码助手 在开始编码之前:我在IDE插件市场搜索腾讯云AI 代码助手,本教程以在 Visual …

【日记】明年或许会是非常重要的一年(1231 字)

正文时间紧迫,简单写写。今天下午全国上下计划财务处条线的人都加班。从 14:30 开始,一直等通知到 15:30 多才开始做,说是系统只开放到 17:00,但是因为找数据、找会计科目、计算会计等式、冲账这一套下来挺花时间也蛮难的,所以我们折腾到了 16:30 左右才搞完。部分支行还涉…

《HarmonyOS第一课》焕新升级,赋能开发者快速掌握鸿蒙应用开发

随着HarmonyOS NEXT发布,鸿蒙生态日益壮大,广大开发者对于系统化学习平台和课程的需求愈发强烈。近日,华为精心打造的《HarmonyOS第一课》全新上线,集“学、练、考”于一体,凭借多维融合的教学模式与系统课程设置,助力开发者快速掌握HarmonyOS应用开发技能。四大课程模块…

【密码学】RSA的攻击方法总结

总结一下收集到的RSA的所有攻击方法。 一、RSA的前世今生 RSA加密算法是一种非对称加密算法。在公开密钥加密和电子商业中RSA被广泛使用。RSA是1977年由罗纳德李维斯特(Ron Rivest)、阿迪萨莫尔(Adi Shamir)和伦纳德阿德曼(Leonard Adleman)一起提出的。RSA就是他们三人姓…

manim边学边做--改变动画速度

ChangeSpeed类是Manim库中用于修改动画速度的类。 它提供了一种灵活的方式来控制动画的播放速度,使动画在不同时间段内以不同的速度播放,从而创造出更加丰富多样的动画效果。 比如,在创建包含多个元素动画的场景中,通过ChangeSpeed可以精确控制不同元素在不同时间点的移动速…

进程间通信组件ZeroMQ详解

在一些复杂的项目中,往往会由不同功能的程序组成,且在程序运行期间,各个程序还需要进行互相通信,实现进程间通信的方式有很多种,最常用的就是通过消息中间件,比如RabbitMQ,Kafaka,以及ZeroMQ等,而RabbitMQ和Kafaka这两款中间件往往都需要独立安装步骤才能使用,ZeroMQ…

Mongodb安装步骤 (.msi安装方式)

我之前发的Mongodb安装步骤 ,被人建议使用 .msi安装方式 所以重新发一版 Mongodb安装步骤 (.msi安装方式) 一、首先下载安装程序 下载链接 Try MongoDB Community Edition | MongoDB 选择 .msi 二、安装 1、双击.msi 2、next: 3、勾选接受,next: 4、complete是默认安装…

[Windows] 数据恢复软件R-Studio 8.14.179623

R-Studio是一个功能强大、节省成本的反删除和数据恢复软件系列。它采用独特的数据恢复新技术,为恢复FAT12/16/32、NTFS、NTFS5(由 Windows 2000/XP/2003/Vista/Windows 8/Windows 10创建或更新)、Ext2FS/Ext3FS(OSX LINUX 文件系统)以及 UFS1/UFS2(FreeBSD/OpenBSD/NetBS…

期末考试

每日总结管理系统: 此软件的主要用户包括学生、小组长、教师;各个用户主要功能为: (1)学生:写日报,修改日报,浏览日报、查询个人日报,查看站内消息。 (2)小组长:日报形式审核,发表情况统计,日报消息,查询日报。 (3)教师:日报评分,发表情况统计,日报消息,查…

【转载】什么是Banner以及测试时需要注意的点

设计中的banner图和测试中的banner图大家好,我是莫宁。相信很多新手小白在近几年也有听说过“banner”吧,是不是很疑惑。反正莫宁刚入门的时候是对这个词很陌生,不知道什么。今天就来为各位小伙伴解答这个疑问吧!什么是Banner?大家都知道“banner”翻译过来是横幅的意思,…

什么是Banner以及测试时需要注意的点

设计中的banner图和测试中的banner图大家好,我是莫宁。相信很多新手小白在近几年也有听说过“banner”吧,是不是很疑惑。反正莫宁刚入门的时候是对这个词很陌生,不知道什么。今天就来为各位小伙伴解答这个疑问吧!什么是Banner?大家都知道“banner”翻译过来是横幅的意思,…