RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1588844
Accepted
drako black
drako black
Asked:2024-07-30 12:14:12 +0000 UTC2024-07-30 12:14:12 +0000 UTC 2024-07-30 12:14:12 +0000 UTC

通过 CSS 设置复选框开关

  • 772

朋友们,帮我完成转换吧...

问题是什么:

总的来说,我决定用 CSS 制作一个带有滑块的标准 chekbox 开关(幸运的是,互联网上有足够多的此类东西),然后我决定向其添加文本“ON”/“OFF” ,然后问题就开始了,如何在纯CSS上不使用JS,让切换滑块时的铭文消失和出现呢?再次,我在互联网上发现@media通常在这种情况下使用的信息,但我没有找到任何关于如何准确执行此操作的信息......

我还尝试了使用“+”的标准选项:

.chek:checked + #off_right {
  visibility: hidden;
}

但似乎我要么没有完成某件事,要么做错了某件事,因为它不起作用。

.chek {
  visibility: hidden;
}
.chekbox {
  position: relative;
  width: 70px;
  height: 30px;
  background-color: red;
  border-radius: 50px;
}
.chekbox:after {
  content: '';
  position: absolute;
  top: 5px;
  right: 3px;
  width: 40px;
  height: 24px;
}

.chek-label {
  position: absolute;
  width: 25px;
  height: 25px;
  border-radius: 50px;
  background-color: black;
  top: 3px;
  left: 3px;
  transition: all 0.4s ease;
  cursor: pointer;
  z-index: 1;
}
.chek:checked + .chek-label {
  left: 40px;
}
#on_left {
  position: absolute;
  visibility: hidden;
  top: 5px;
  left: 5px;
  text-align: center;
  vertical-align: middle;
  font-weight: bold;
}
#off_right {
  position: absolute;
  visibility: visible;
  top: 5px;
  right: 5px;
  text-align: center;
  vertical-align: middle;
  font-weight: bold;
}
@media (checked) {
  #on_left {
    visibility: visible;
  }
  #off_right {
    visibility: hidden;
  }
}
<div class="chekbox">
  <input type="checkbox" id="btn_audio" class="chek">
  <label for="btn_audio" class="chek-label"></label>
  <span id="on_left">ON</span>
  <span id="off_right">OFF</span>
</div>

我将不胜感激的帮助和解释。另外,如果有人可以分享有关这一切如何运作的合理信息来源,我也将不胜感激。

PS 我所说的“明智”是指来源不是来自“2+2=4,现在求解积分”类别,而是来自“它像这样工作,但要得到这个,你需要使用这个”类别。 (一般来说,一切都用人类语言详细解释)。

html
  • 1 1 个回答
  • 25 Views

1 个回答

  • Voted
  1. Best Answer
    Михаил Камахин
    2024-07-30T13:41:43Z2024-07-30T13:41:43Z

    :root {
      --transitionDuration: 0.4s;
      --transitionTimingFunction: ease;
    }
    
    .chek {
      visibility: hidden;
    }
    
    .checkbox {
      position: relative;
      display: block;
      width: 70px;
      height: 30px;
      background-color: red;
      border-radius: 50px;
      cursor: pointer;
      user-select: none;
      transition: background-color var(--transitionDuration) var(--transitionTimingFunction);
    }
    
    
    .chek-label {
      position: absolute;
      width: 25px;
      height: 25px;
      border-radius: 50px;
      background-color: black;
      top: 3px;
      left: 3px;
      z-index: 1;
      transition: transform var(--transitionDuration) var(--transitionTimingFunction);
    }
    .chek:checked + .chek-label {
      transform: translateX(40px);
    }
    
    .on-left, .off-right {
      transition-property: opacity, visibility;
      transition-timing-function: var(--transitionTimingFunction);
      transition-duration: var(--transitionDuration);
    }
    
    .on-left {
      position: absolute;
      visibility: hidden;
      opacity: 0;
      top: 5px;
      left: 5px;
      text-align: center;
      vertical-align: middle;
      font-weight: bold;
    }
    
    .off-right {
      position: absolute;
      visibility: visible;
      opacity: 1;
      top: 5px;
      right: 5px;
      text-align: center;
      vertical-align: middle;
      font-weight: bold;
    }
    
    .chek:checked ~ .off-right {
      opacity: 0;
      visibility: hidden;
    }
    
    .chek:checked ~ .on-left {
      opacity: 1;
      visibility: visible;
    }
    
    .checkbox:has(.chek:checked) {
      background-color: limegreen;
    }
    <label class="checkbox">
      <input type="checkbox" id="btn_audio" class="chek">
      <span class="chek-label"></span>
      <span class="on-left">ON</span>
      <span class="off-right">OFF</span>
    </label>

    • 1

相关问题

  • 具有非均匀背景的块内的渐变边框

  • 离开页脚

  • 如何将三个字段的数据收集到一封电子邮件中?

  • Html 元素刚从父元素中出来

  • 如何在css中制作这个背景?

  • 如何制作带有斜条纹的背景?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5