【问题标题】:CSS Toggle Switch(Checkbox) value always on/checkedCSS切换开关(复选框)值始终打开/选中
【发布时间】:2019-09-14 19:01:57
【问题描述】:

我只是在 CSS 中将 checkbox 设置为 toggle switch,它工作正常。但是,onchange 事件的输入值似乎没有变化,并且始终显示on

JS代码:

/* The switch - the box around the slider */
.switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;
}

/* Hide default HTML checkbox */
.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

/* The slider */
.slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  -webkit-transition: .4s;
  transition: .4s;
}

.slider:before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: white;
  -webkit-transition: .4s;
  transition: .4s;
}

input:checked + .slider {
  background-color: #2196F3;
}

input:focus + .slider {
  box-shadow: 0 0 1px #2196F3;
}

input:checked + .slider:before {
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px);
}

/* Rounded sliders */
.slider.round {
  border-radius: 34px;
}

.slider.round:before {
  border-radius: 50%;
}
<html>
  <head>
  </head>
  <body>
    <center>
      <label class="switch">
        <input type="checkbox" onchange="console.log(this.value);">
        <span class="slider round"></span>
      </label>
    </center>
  </body>
</html>

它的视觉行为是完美的,但不是内部的。导致问题的原因是什么?有什么想法吗?

【问题讨论】:

    标签: javascript html css dom-events uiswitch


    【解决方案1】:

    工作示例:https://jsfiddle.net/mg7sLa21/

    使用选中的属性来确定复选框的状态,然后根据该状态分配一个值。

    JS

    document.getElementById('checkbox1').addEventListener('change', (e) => {
      this.checkboxValue = e.target.checked ? 'on' : 'off';
      console.log(this.checkboxValue)
    })
    

    HTML

    <html>
    
      <head>
      </head>
    
      <body>
        <center>
          <label class="switch">
            <input id="checkbox1" type="checkbox">
            <span class="slider round"></span>
          </label>
        </center>
      </body>
    
    </html>
    

    【讨论】:

      【解决方案2】:

      在一行中,它是特定于浏览器的。 Checkbox 具有 checked 属性,您可以通过它来区分它是否被选中(开/关)/(真/假)。 如果您想打印其他内容而不是“ON”,请添加 value='true' value='passed value' 属性,该属性将始终打印 true 或传递的值。

      <input type="checkbox" onchange="console.log(this.checked)">
      

      【讨论】:

        猜你喜欢
        • 2013-08-24
        • 2013-09-23
        • 2018-08-08
        • 2021-01-25
        • 2011-05-09
        • 2017-02-06
        • 2020-06-01
        • 1970-01-01
        相关资源
        最近更新 更多