Han*_*nny 1 html css jquery twitter-bootstrap bootstrap-4
我搜索并找到了一些类似的答案 - 但那些是围绕我没有使用的手风琴。
我嵌套了折叠项目,如本 codepen 中所示
$('#collapseOutter').on('show.bs.collapse', function(event) {
$('#collapseBtn').html("Show Less");
console.log('Only happen when outter div is opened');
event.stopPropagation();
console.log('even with stopping propagation it fires');
})
$('#collapseOutter').on('hide.bs.collapse', function() {
$('#collapseBtn').html("Show More");
console.log('Only happen when outter div is collapsed');
})Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0/js/bootstrap.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet" />
<div class="container">
<div class="row ml-4">
<div class="row header-div">
<a id="collapseBtn" class="btn-info btn" data-toggle="collapse" href="#collapseOutter" role="button" aria-expanded="false" aria-controls="collapseOutter">
Show More
</a>
</div>
</div>
<div class="row ml-4">
<div id="collapseOutter" class="collapse">
<p>Here is a paragraph about the data you're about to see.</p>
<div class="row">
<div id="item-a">
<a id="item-a" class="" data-toggle="collapse" href="#collapseInnerA">
Item One of a list
</a>
<br />
<div id="collapseInnerA" class="collapse">
<div class="row">
<p class="ml-4">Item One Related Information</p>
</div>
</div>
</div>
</div>
<div class="row">
<div id="item-b">
<a id="item-b" class="" data-toggle="collapse" href="#collapseInnerB">
Item Two of a list
</a>
<br />
<div id="collapseInnerB" class="collapse">
<div class="row">
<p class="ml-4">Item Two Related Information</p>
</div>
</div>
</div>
</div>
</div>
</div>
</div>Run Code Online (Sandbox Code Playgroud)
当我单击列表中的项目(位于第一个折叠内)时,它会导致父方法触发。
当我单击列表项以折叠/显示其信息时,如何防止父方法触发?
我正在寻找如何专门针对引导程序执行此操作。
当事件传播到达外部崩溃时,您将停止事件传播。你应该在内心崩溃时停止它。在此 codepen中,第一个内部崩溃的崩溃事件将冒泡,而第二个内部崩溃事件将停止。
$('#collapseInnerB').on('show.bs.collapse', function( event ) {
event.stopPropagation();
})
$('#collapseInnerB').on('hide.bs.collapse', function( event ) {
event.stopPropagation();
})
Run Code Online (Sandbox Code Playgroud)