示例HTML:
<div id="foo" class="class_one"></div>
如何在不替换class_two
的情况下添加课程class_one
?
最终结果:
<div id="foo" class="class_one class_two"></div>
答案 0 :(得分:56)
标准javascript:
document.getElementById('foo').className += ' class_two'
// Or see deekshith's answer below if you only need to support new browsers
或JQuery:
$('#foo').addClass('class_two');
答案 1 :(得分:18)
您可以使用jQuery。
$('#YourElement').addClass('YourClass'); //add
$('#YourElement').removeClass('YourClass'); //remove
$('#YourElement').toggleClass('YourClass'); //toggle
或者Javascript,如果你愿意的话。
document.getElementById('id').classList.add('YourClass'); //add
document.getElementById('id').classList.remove('YourClass'); //remove
答案 2 :(得分:11)
添加课程的更好方法是使用Element.classList.add():
document.getElementById('foo').classList.add("class_two");
答案 3 :(得分:3)
使用几个辅助函数可以让生活更轻松:
function addClass(el, className) {
var classes = el.className.match(/\S+/g) || [];
if (!hasClass(el, className)) {
classes.push(className);
}
el.className = classes.join(' ');
}
function hasClass(el, className) {
var re = new RegExp('(^|\\s+)' + className + '(\\s+|$)');
return re.test(el.className);
}
addClass(document.getElementById('foo'), 'bar')