【问题标题】:Accordion closes except when clicking icon手风琴关闭,除非单击图标
【发布时间】:2020-05-19 18:34:59
【问题描述】:

我正在运行以下手风琴设置。除了这个小问题之外,一切都运行得很好:一旦手风琴打开,您无法通过单击 V 形图标将其关闭。它会在手风琴的其他任何地方关闭,但不会在人字形本身上关闭。知道为什么会发生这种情况以及如何解决这个微小但令人讨厌的问题吗?非常感谢任何指导。谢谢。

这里是小提琴:https://jsfiddle.net/oh823pxz/

$(function() {

  $('.accordion .accordion-title').on('click', toggleAccordion);

  function toggleAccordion(event) {
  
   $('.accordion-item').not($(event.target).parent()).removeClass('is-open');
    var target = $(event.target).closest('.accordion-item');

    target.parent('.accordion').find('.accordion-item').not(target).removeClass('is-open');
    target.toggleClass('is-open');
  }
  
});
.accordion .accordion-item {
  border-bottom: 1px solid #000;
}

.accordion .accordion-title {
  position: relative;
  padding: 15px;
  cursor: pointer;
}

.accordion .accordion-content {
  display: none;
  padding: 0 15px 15px;
}

.accordion .accordion-item.is-open .accordion-content {
  display: block;
}

.accordion .arrow {
  position: absolute;
  display: inline-block;
  padding: 5px;
  top: 13px;
  right: 15px;
  background-color: inherit;
  border: solid #000;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
}

.accordion .accordion-item.is-open .arrow {
  top: 20px;
  transform: rotate(-135deg);
  -webkit-transform: rotate(-135deg);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<div class="accordion">
  <div class="accordion-item">
    <div class="accordion-title">
      TITLE 1
      <span class="arrow"></span>
    </div>
    <div class="accordion-content">
      CONTENT 1
    </div>
  </div>
</div>
  
 <div class="accordion">
  <div class="accordion-item">
    <div class="accordion-title">
      TITLE 2
      <span class="arrow"></span>
    </div>
    <div class="accordion-content">
      CONTENT 2
    </div>
  </div>
  <div class="accordion-item">
    <div class="accordion-title">
      TITLE 3
      <span class="arrow"></span>
    </div>
    <div class="accordion-content">
      CONTENT 3
    </div>
  </div>
</div>

【问题讨论】:

    标签: javascript css icons accordion


    【解决方案1】:

    试试这个... z-index: -1;

    .accordion .accordion-item.is-open .arrow {
        top: 20px;
        transform: rotate(-135deg);
        -webkit-transform: rotate(-135deg);
        z-index: -1;
    }
    

    【讨论】:

      【解决方案2】:

      .arrow 跨度不响应点击,因此尝试点击箭头不会执行任何操作。

      一种解决方法是将pointer-events: none 添加到.arrow 规则中。然后点击传递给父级。

      .accordion .arrow {
        position: absolute;
        display: inline-block;
        padding: 5px;
        top: 13px;
        right: 15px;
        background-color: inherit;
        border: solid #000;
        border-width: 0 2px 2px 0;
        transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
      
        /* prevents clicks */
        pointer-events: none; 
      }
      

      $(function() {
      
        $('.accordion .accordion-title').on('click', toggleAccordion);
      
        function toggleAccordion(event) {
        
         $('.accordion-item').not($(event.target).parent()).removeClass('is-open');
          var target = $(event.target).closest('.accordion-item');
      
          target.parent('.accordion').find('.accordion-item').not(target).removeClass('is-open');
          target.toggleClass('is-open');
        }
        
      });
      .accordion .accordion-item {
        border-bottom: 1px solid #000;
      }
      
      .accordion .accordion-title {
        position: relative;
        padding: 15px;
        cursor: pointer;
      }
      
      .accordion .accordion-content {
        display: none;
        padding: 0 15px 15px;
      }
      
      .accordion .accordion-item.is-open .accordion-content {
        display: block;
      }
      
      .accordion .arrow {
        position: absolute;
        display: inline-block;
        padding: 5px;
        top: 13px;
        right: 15px;
        background-color: inherit;
        border: solid #000;
        border-width: 0 2px 2px 0;
        transform: rotate(45deg);
        -webkit-transform: rotate(45deg);
        pointer-events: none;
      }
      
      .accordion .accordion-item.is-open .arrow {
        top: 20px;
        transform: rotate(-135deg);
        -webkit-transform: rotate(-135deg);
      }
      <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
      
      <div class="accordion">
        <div class="accordion-item">
          <div class="accordion-title">
            TITLE 1
            <span class="arrow"></span>
          </div>
          <div class="accordion-content">
            CONTENT 1
          </div>
        </div>
      </div>
        
       <div class="accordion">
        <div class="accordion-item">
          <div class="accordion-title">
            TITLE 2
            <span class="arrow"></span>
          </div>
          <div class="accordion-content">
            CONTENT 2
          </div>
        </div>
        <div class="accordion-item">
          <div class="accordion-title">
            TITLE 3
            <span class="arrow"></span>
          </div>
          <div class="accordion-content">
            CONTENT 3
          </div>
        </div>
      </div>

      【讨论】:

        【解决方案3】:

        我不会使用 CSS 来修复 jQuery 问题,如果您要更改图标,这会给您带来更多问题。我稍微编辑了脚本并稍微改变了逻辑。它现在应该可以工作了:

        示例代码 https://jsfiddle.net/s8w15bu7/2/

        HTML(添加的 JS 类)

        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
        
         <div class="accordion">
          <div class="accordion-item js-accordionItem">
            <div class="accordion-title js-accordionTitle">
              TITLE 2
              <span class="arrow"></span>
            </div>
            <div class="accordion-content">
              CONTENT 2
            </div>
          </div>
          <div class="accordion-item js-accordionItem">
            <div class="accordion-title js-accordionTitle">
              TITLE 3
              <span class="arrow"></span>
            </div>
            <div class="accordion-content">
              CONTENT 3
            </div>
          </div>
        </div>
        

        CSS(我这里没有改变任何东西)

        .accordion .accordion-item {
          border-bottom: 1px solid #000;
        }
        
        .accordion .accordion-title {
          position: relative;
          padding: 15px;
          cursor: pointer;
        }
        
        .accordion .accordion-content {
          display: none;
          padding: 0 15px 15px;
        }
        
        .accordion .accordion-item.is-open .accordion-content {
          display: block;
        }
        
        .accordion .arrow {
          position: absolute;
          display: inline-block;
          padding: 5px;
          top: 13px;
          right: 15px;
          background-color: inherit;
          border: solid #000;
          border-width: 0 2px 2px 0;
          transform: rotate(45deg);
          -webkit-transform: rotate(45deg);
        }
        
        .accordion .accordion-item.is-open .arrow {
          top: 20px;
          transform: rotate(-135deg);
          -webkit-transform: rotate(-135deg);
        }
        

        JS/Jquery

        $(function() {
        
          $('.js-accordionTitle').on('click', toggleAccordion);
        
          function toggleAccordion(event) {
            const classOpen = "is-open";
            let jqThis = $(this);
            let currentItem = jqThis.closest('.js-accordionItem');
        
            if (!currentItem.hasClass(`${classOpen}`)) {
                currentItem.siblings().removeClass(`${classOpen}`);
              currentItem.addClass(`${classOpen}`);
            } else {
                currentItem.removeClass(`${classOpen}`);
            }
          }
        
        });
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2017-10-26
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2015-02-17
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多