it-roy-ru.com

Как определить, открывается или закрывается загрузочный коллапс?

Если у меня произошел крах начальной загрузки, как я могу определить по событию щелчка, открывается или закрывается этот крах?

Вот мое событие click или, может быть, есть лучший способ использовать событие click?

$(document).on("click", "a.register-student-link", function() {
    // do some stuff to check if opening or closing
}

<div>
  <a [email protected] class="register-student-link" data-toggle="collapse" [email protected] aria-expanded="false" aria-controls="collapseExample">
                                                    Register Student
                                                </a>
</div>

18
user1186050

Bootstrap использует расширенный атрибут aria, чтобы показать true или false, если область свернута или нет.

var isExpanded = $(collapsableRegion).attr("aria-expanded");
22
user1186050

Пытаться:

$('#collapseDiv').on('shown.bs.collapse', function () {
   console.log("Opened")
});

$('#collapseDiv').on('hidden.bs.collapse', function () {
   console.log("Closed")
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" rel="stylesheet"/>
<div>
  <a [email protected] class="register-student-link" data-toggle="collapse" href="#collapseDiv" aria-expanded="false" aria-controls="collapseExample">Register Student</a>
</div>

<div class="collapse" id="collapseDiv">This is the collapsible content!</div>

(на основе https://stackoverflow.com/a/18147817/2033574 (упомянуто Кевином) и http://www.bootply.com/73101 )

19
Josiah Krutz

Мне нужен был способ определить, был ли элемент свернут ПРЕЖДЕ ЧЕМ фактически разрушаться. В то время как слушатели событий срабатывают только после этого.

//Will return true if uncollapsed
$('#collapseDiv').hasClass('in');

//Will return true if in the process of collapsing
$('#collapseDiv').hasClass('collapsing');

//Will return true if collapsed
$('#collapseDiv').hasClass('collapse');
13
adam3039

Вы можете посмотреть событие hidden.bs.collapse

см. скрипку: http://jsfiddle.net/kyeuvx1d/

2
Kevin Friedheim
function checkStatus() {

    if($('#item1').hasClass('in')) {
        alert('closing')    
    } else {
        alert('opening')    
    }   
}

checkStatus()
0
Joyal