使用javascript将类添加到DIV

时间:2012-07-12 03:28:57

标签: javascript html css

示例HTML:

<div id="foo" class="class_one"></div>

如何在不替换class_two的情况下添加课程class_one

最终结果:

<div id="foo" class="class_one class_two"></div>

4 个答案:

答案 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')