如何使用时间指示器创建 bootstrap 自动隐藏模式?

How can I create bootstrap auto hide modal with time indicator?

我有一个模式调用者 link 和一个模式如下:

<!-- modal caller -->
<a href="#" data-toggle="modal" data-target="#modal">CALL MODAL</a>
<!-- modal -->
<div id="modal" class="modal auto-hide-modal" data-time="3000" data-backdrop="static" data-keyboard="false" tabindex="-1">
    <div class="modal-dialog modal-xl modal-dialog-scrollable">
        <div class="modal-content">
            <div class="modal-header">
                <h5 class="modal-title">MY TITLE</h5>
            </div>
            <div class="modal-body">MY TEXT</div>
            <div class="modal-footer">
                <div class="progress" style="height: .25rem;">
                    <div id="time_indicator" class="progress-bar" role="progressbar"></div>
                </div>
            </div>
        </div>
    </div>
</div>

我有这些脚本:

$(document).on('shown.bs.modal', '.auto-hide-modal', function () {
    var time = $(this).data('time');
    $(this).delay(time).fadeOut(300, function () {
        $(this).modal('hide');
    });
});

到目前为止,还不错。 我希望进度条 (time_indicator) 显示模式关闭的剩余时间。

你必须使用jQuery动画函数并将动画速度设置为时间。然后将宽度重置为0;所以下次打开模式时,动画会再次执行。

CSS:

#time_indicator {
  width: 0;
}

JavaScript:

$(document).on('shown.bs.modal', '.auto-hide-modal', function () {
    var time = $(this).data('time');
    $("#time_indicator").animate({width: "100%"}, time);
    $(this).delay(time).fadeOut(300, function () {
        $(this).modal('hide');
        $("#time_indicator").css("width", 0);
    });
});