[英]How do I cycle through multiple Bootstrap3 modals with next/prev links
I am trying to cycle through multiple Bootstrap3 modals via next and prev links inside the current open modal. 我正在尝试通过当前打开模式中的next和prev链接循环浏览多个Bootstrap3模式。 The script I have does go to the next modal along if you click 'next', or back to the previous modal if you click 'prev', but I can nolonger use the data-dismiss="modal" functionality to hide the modal.
如果您单击“下一步”,我所拥有的脚本将转到下一个模态,如果您单击“上一个”,则返回前一个模态,但是我将不再使用data-dismiss =“ modal”功能来隐藏模态。 Plus, my JQuery seems rather hacky.
另外,我的JQuery似乎很hacky。 Is there a better way?
有没有更好的办法? Any help welcome.
任何帮助欢迎。
<button class="text-link" data-toggle="modal" data-target="#modalOne">Modal One</button>
<div class="modal fade default-modal" tabindex="-1" role="dialog" id="modalOne">
<div class="modal-dialog modal-md" role="document">
<div class="modal-content">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><i class="fa fa-times" aria-hidden="true"></i></button>
<a class="next"></a>
<a class="prev"></a>
<div class="modal-body">
Hello Earth
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div><!-- /.modal -->
<button class="text-link" data-toggle="modal" data-target="#modalTwo">Modal Two</button>
<div class="modal fade default-modal" tabindex="-1" role="dialog" id="modalTwo">
<div class="modal-dialog modal-md" role="document">
<div class="modal-content">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><i class="fa fa-times" aria-hidden="true"></i></button>
<a class="next"></a>
<a class="prev"></a>
<div class="modal-body">
Hello Mars
</div>
</div><!-- /.modal-content -->
</div><!-- /.modal-dialog -->
</div><!-- /.modal -->
$(document).ready(function() {
$('a.next').on('click', function() {
$(this).closest('.modal').css("display", "none");
$(this).closest('.modal').removeClass('in').next().addClass('in').css("display", "block");
});
$('a.prev').on('click', function() {
$(this).closest('.modal').css("display", "none");
$(this).closest('.modal').removeClass('in').prev().addClass('in').css("display", "block");
});
});
You can try using the built-in show hide functionality of the modal
say: 您可以尝试使用
modal
的内置show hide功能:
$(document).ready(function() {
$('a.next').on('click', function() {
let dialog = $(this).closest('.modal');
dialog.modal('hide');
dialog.next().modal('show');
});
$('a.prev').on('click', function() {
let dialog = $(this).closest('.modal');
dialog.modal('hide');
dialog.prev().modal('show');
});
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.