it-swarm.com.ru

Bootstrap modal - скрыть одно, а затем показать другое

Я давно использую jQueryUI, но недавно по эстетическим соображениям переключился на Bootstrap. Сейчас я борюсь с тем, что, как я ожидал, будет простой проблемой, и задавался вопросом, может ли это помочь мне тем, кто более знаком с Bootstrap.

У меня есть общая функция для создания диалогов на лету, и бывают случаи, когда я показываю диалог без кнопок (при обработке чего-либо), а затем меняю его на диалог, в котором есть кнопки (процесс завершен - нажмите OK, чтобы пример). Я не пытаюсь определить процесс установки здесь, поэтому я говорю, что хочу иметь возможность закрыть одно диалоговое окно и открывать другое при необходимости. Вот где проблема приходит.

С помощью Bootstrap диалоги оживляются и исчезают, и мне это нравится, и я хочу сохранить их. Я не хочу делать это при смене диалогов. Я могу сделать это, удалив класс fade из первого диалогового окна, когда оно отображается, и из второго диалогового окна, прежде чем оно отобразится, и это прекрасно работает. Затем я добавляю класс ко второму диалогу, чтобы он оживил. Тем не менее, анимация идет не так, когда я делаю это, и есть ужасная вспышка, где фоновый div должен плавно исчезать.

Я собрал jsfiddle, чтобы продемонстрировать проблему. Вы можете нажать кнопку закрытия в первом диалоговом окне, чтобы увидеть, как выглядит анимация затухания должна.

Любая помощь будет оценена, прежде чем я начну копаться в исходных файлах Bootstrap.

http://jsfiddle.net/ArchersFiddle/0302gLav/1/

tl; dr

Посмотрите на jsfiddle - нажмите «Показать диалог 2» - нажмите «ОК». Я хочу избавиться от черной вспышки в конце.

CSS

@import url("//maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css");
.modal {
    display: none;
}

HTML

<div id="dialog1" class="modal fade">
  <div class="modal-dialog">
    <div class="modal-content">
      <div class="modal-header">
        <h4 class="modal-title">Modal Dialog 1</h4>
      </div>
      <div class="modal-body">This is the first modal dialog</div>
      <div class="modal-footer">
        <button type="button" id="dialog-ok" class="btn btn-default">Show dialog 2</button>          
        <button type="button" id="dialog-close" class="btn btn-default" data-dismiss="modal">Close</button>          
      </div>
    </div>
  </div>
</div>

<div id="dialog2" class="modal">
  <div class="modal-dialog">
    <div class="modal-content">
      <div class="modal-header">
        <h4 class="modal-title">Modal Dialog 2</h4>
      </div>
      <div class="modal-body">This is the second modal dialog</div>
      <div class="modal-footer">
        <button type="button" class="btn btn-default" data-dismiss="modal">OK</button>          
      </div>
    </div>
  </div>
</div>

JavaScript

function showDialog2() {
    $("#dialog1").removeClass("fade").modal("hide");
    $("#dialog2").modal("show").addClass("fade");
}

$("#dialog1").modal("show");

$("#dialog-ok").on("click", function() {
    showDialog2();
});
6
Archer

Ладно, я не люблю отвечать на свой вопрос, но у меня есть решение, которое на 100% надежно (насколько я могу судить). Я закончил тем, что выбрал решение, которое проверяет существующий диалог и модифицирует его, а не скрывает и показывает новый.

Вот рабочий jsfiddle (используя echo в вызове ajax, где он обычно загружает html-шаблон) ...

http://jsfiddle.net/ArchersFiddle/0302gLav/9/

Код является частью большой библиотеки, над которой я работаю, но в любом случае я опубликую ее здесь, поскольку она может оказаться полезной для других.

JavaScript Library

(function () {

    var _defaultOptions = {
        backdrop: "static",
        close: true,
        keyboard: true
    };

    window.bootstrap = {
        modal: {
            show: function (options) {

                options = $.extend(_defaultOptions, options);

                var buttonText = "";

                for (var key in options.buttons) {

                    options.buttons[key].id = "button_" + key.split(" ").join("");

                    var button = options.buttons[key];

                    buttonText += "<button type=\"button\" " +
                        "id=\"" + button.id + "\" " +
                        "class=\"btn " +
                        (typeof (button.class) == "undefined" ? "btn-default" : button.class) + "\" " +
                        (typeof (button.dismiss) == "undefined" ? "" : "data-dismiss=\"modal\" ") + ">" +
                        key + "</button>";
                }

                $.ajax({
                    url: "templates/bootstrap-modal.html"
                })
                .done(function (data) {
                    data = data
                        .replace("{:Title}", options.title)
                        .replace("{:Body}", options.body)
                        .replace("{:Buttons}", buttonText);

                    var $modal = $("#bootstrap-modal");
                    var existing = $modal.length;

                    if (existing) {
                        $modal.html($(data).find(".modal-dialog"));
                    }
                    else {
                        $modal = $(data).appendTo("body");
                    }

                    for (var key in options.buttons) {
                        var button = options.buttons[key];
                        if (typeof (button.callback) !== undefined) {
                            $("#" + button.id).on("click", button.callback);
                        }
                    }

                    $modal.off("shown.bs.modal").on("shown.bs.modal", function(e) {
                        if (typeof(options.onshow) === "function") {
                            options.onshow(e);
                        }
                    });

                    if (!existing) {
                        $modal.modal(options);
                    }

                    if (options.large === true) {
                        $modal.find(".modal-dialog").addClass("modal-lg");
                    }

                    if (options.close === false) {
                        $modal.find("button.close").remove();
                    }
                });
            },
            hide: function (callback) {
                var $modal = $("#bootstrap-modal");

                if (!$modal.length) return;

                $modal.on("hidden.bs.modal", function(e) {
                    $modal.remove();
                    if (typeof(callback) === "function") {
                        callback(e);
                    }
                });

                $modal.modal("hide");
            }
        }
    };
})();

Шаблон HTML

<div id="bootstrap-modal" class="modal fade">
  <div class="modal-dialog">
    <div class="modal-content">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal"><span aria-hidden="true">&times;</span><span class="sr-only">Close</span></button>
        <h4 class="modal-title">{:Title}</h4>
      </div>
      <div class="modal-body">{:Body}</div>
      <div class="modal-footer">
        {:Buttons}
      </div>
    </div>
  </div>
</div>

Пример использования:

bootstrap.modal.show({
    title: "Dialog Title",
    body: "<p>This is the dialog body and can contain any old html rubbish.</p>",
    buttons: {
        Close: {
            dismiss: true
        }
    }
});

Дополнительные параметры объяснены

bootstrap.modal.show({
    backdrop: true,                     // show the backdrop
    close: true,                        // show the close button
    keyboard: true,                     // allow the keyboard to close the dialog
    title: "Dialog Title",
    body: "<p>This is the dialog body and can contain any old html rubbish.</p>",
    buttons: {
        Button1: {
            class: "btn-primary",           // any class you want to add to the button
            dismiss: false,                 // does this button close the dialog?
            callback: function() {          // button click handler
                // the button was clicked - do something here
            }
        },
        Button2: {
            // options as defined as above.  You can have as many buttons as you want
        }
    },
    onshow: function(e) {
        // this will trigger when the dialog has completed the show animation
    }
});

а также

bootstrap.modal.hide(function(e) {
    // this will trigger when the dialog has completed the hide animation
});

Все параметры в методе show() являются необязательными, но, очевидно, вам потребуются заголовок и тело.

3
Archer

UPDATED:

Я добавил обработчик click() для вашей последней кнопки с добавленным идентификатором теста id="test", где диалоговое окно и фон исчезают с помощью эффекта fadeOut() . Важным моментом является исчезновение элемента .modal-backdrop, который инкапсулирует как диалог, так и фон:

$("#test").on("click", function () {
    $(".modal-backdrop").fadeOut("slow");
});

 

JsFiddle

4
urbz
function showDialog2() {
$("#dialog1").removeClass("fade").modal("hide");
$("#dialog2").addClass("fade").modal("show");

}

вы хотите быть это

2
esref

У меня есть код, как закрыть открытый модальный, прежде чем открывать другой.

$('[data-toggle="modal"]').on('click', function() { //On click a button which call a modal
    if(($(".modal").data('bs.modal') || {}).isShown){ //If a modal is shown
        var modal = $(".modal.in"); // Get the current element
        $(modal).modal('hide'); // Hide the current modal
    }
});

Надеюсь, что это помогло!

0
Antony GUEDJ