2 回答
![?](http://img1.sycdn.imooc.com/54584d6100015f5802200220-100-100.jpg)
TA贡献1828条经验 获得超4个赞
var month = document.getElementById("filt-monthly"),
annual = document.getElementById("filt-annual"),
swicther = document.getElementById("switcher"),
montWrapper = document.getElementById("monthly"),
annualWrapper = document.getElementById("annually");
month.addEventListener("click", function(){
month.classList.add("toggler--is-active");
annual.classList.remove("toggler--is-active");
montWrapper.classList.remove("hide");
annualWrapper.classList.add("hide");
document.querySelector("[type='checkbox']").checked = false
});
annual.addEventListener("click", function(){
month.classList.remove("toggler--is-active");
annual.classList.add("toggler--is-active");
montWrapper.classList.add("hide");
annualWrapper.classList.remove("hide");
document.querySelector("[type='checkbox']").checked = true
});
swicther.addEventListener("click", function(event){
month.classList.toggle("toggler--is-active");
annual.classList.toggle("toggler--is-active");
montWrapper.classList.toggle("hide");
annualWrapper.classList.toggle("hide");
})
我更改了一些代码并更改了变量名称以提高可读性。这是可行的,但我认为这不是有效的代码。
![?](http://img1.sycdn.imooc.com/5458631e0001ffd402200220-100-100.jpg)
TA贡献2039条经验 获得超7个赞
在 html 和 css 中更改了切换、检查和切换。随意使用这个。
HTML
<div style="" class="container pb-2" id="signupForm">
<div class="toggler pointer" id="filt-monthly">Monthly </div>
<label class="toggle">
<input type="checkbox" id="switcher" class="check"/>
<b class="b switch"></b>
</label>
<div class="toggler pointer" id="filt-annual"> Annual</div>
</div>
CSS
.toggler {
display: inline-block;
vertical-align: middle;
margin: 12px 0 0 0;
color: #ddd;
transition: .2s;
font-weight: bold;
}
.toggler--is-active {
color: #000000;
}
.b {
display: block;
}
.hide{
display: none;
}
/* slide/switch */
.toggle {
position: relative;
display: inline-block;
width: 60px;
height: 34px;
}
.toggle input {
opacity: 0;
width: 0;
height: 0;
}
.switch {
position: absolute;
top: 0; right: 0; bottom: 0; left: 0;
cursor: pointer;
background-color: #999;
-webkit-transition: .4s;
transition: .4s;
border-radius: 34px;
}
.switch:before {
position: absolute;
bottom: 4px; left: 4px;
content: "";
width: 26px;
height: 26px;
background-color: #fff;
-webkit-transition: .4s;
transition: .4s;
border-radius: 50%;
}
input:checked + .switch {
background-color: #f66;
}
input:focus + .switch {
box-shadow: 0 0 1px #f66;
}
input:checked + .switch:before {
-webkit-transform: translateX(26px);
-ms-transform: translateX(26px);
transform: translateX(26px);
}
添加回答
举报