我们有 addClass、removeClass、toggleClass
jQuery相当于什么
document.getElementById("field").className=(someBoolean)?"pass":"fail";
但是使用保留现有类的方法之一?
我最接近的是在我看来不是那么优雅
$("#field")
.toggleClass("pass",someBoolean)
.toggleClass("fail",!someBoolean);
或者使用变量
$("#field")
.toggleClass(classWhenTrue,someBoolean)
.toggleClass(classWhenFalse,!someBoolean);
例子:
$(function() {
var pass = true;
$("#field")
.toggleClass("pass", pass)
.toggleClass("fail", !pass);
var classes = [...$("#field").get(0).classList];
console.log(classes)
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<input id="field" type="text" class="test fail done" />