首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在两个元素之间切换一个类

在两个元素之间切换一个类
EN

Stack Overflow用户
提问于 2017-10-17 06:51:30
回答 2查看 1.2K关注 0票数 2

我有这个html:

代码语言:javascript
复制
<div class="container">
   <div id="element-1" class="element-show"></div>
   <div id="element-2"></div>
</div>

我希望类element-show能够隐藏element-1,并在element-2中显示,反之亦然;从jQuery中的一个函数调用。

我能做好这件事吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2017-10-17 07:35:17

这样的事可以吗?

代码语言:javascript
复制
$("button").on("click", function(e){
  $('.container').children("div").toggleClass("element-show");
})
代码语言:javascript
复制
.element-show{
color:red;
}
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="container">
   <div id="element-1" class="element-show">x</div>
   <div id="element-2">y</div>
</div>
<button>Toggle class</button>

票数 3
EN

Stack Overflow用户

发布于 2017-10-17 07:37:23

您可以通过这样做来实现这一点:

代码语言:javascript
复制
function getClass() {
  var children_container = document.getElementsByClassName("container")[0].children;

  for (var i = 0; i < children_container.length; i++) {
    if ($(children_container[i]).hasClass('element-show')) {
      $(children_container[i]).removeClass();
      if (i == "0") {
        $(children_container[1]).addClass("element-show");
        break;
      } else if (i == "1") {
        $(children_container[0]).addClass("element-show");
        break;
      }
    }
  };
};

getClass();
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

<div class="container">
  <div id="element-1" class="element-show"></div>
  <div id="element-2"></div>
</div>

如果您有两个以上的元素,并且希望在其余元素上添加类,并将其从已经拥有该类的元素中删除,那么您可以通过这样做来实现这一点(此函数也适用于您提到的情况):

代码语言:javascript
复制
function getClass() {
  var children_container = document.getElementsByClassName("container")[0].children;
  var class_elem;
  for (var i = 0; i < children_container.length; i++) {
    if ($(children_container[i]).hasClass('element-show')) {
      class_elem = i;
      $(children_container[i]).removeClass();
      i = 0;
    }
    if (class_elem != undefined) {
      if (i != class_elem) {
        $(children_container[i]).addClass('element-show');
      }
    };
  };
};

getClass();
代码语言:javascript
复制
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="container">
  <div id="element-0"></div>
  <div id="element-1" class="element-show"></div>
  <div id="element-2"></div>
  <div id="element-3"></div>
  <div id="element-4"></div>
</div>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46784121

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档