С помощью bootbox событие show не запускается
Я не могу поймать событие show для диалога bootbox.confirm, чтобы выполнить некоторые настройки css в диалоговом окне, прежде чем показывать его.
Я пробовал такие вещи, как следующие, но не удалось:
$(document).on("show.bs.modal", function (event) {...});
$(document).on("show", function (event) {...});
$(document).on("show", ".bootbox", function (event) {...});
Ответы
Ответ 1
Я также предпочел бы использовать глобальную функцию, например:
function bootbox_confirm(msg, callback_success, callback_cancel) {
var d = bootbox.confirm({message:msg, show:false, callback:function(result) {
if (result)
callback_success();
else if(typeof(callback_cancel) == 'function')
callback_cancel();
}});
d.on("show.bs.modal", function() {
//css afjustment for confirm dialogs
alert("before show");
});
return d;
}
и назовите его следующим образом:
bootbox_confirm("my message", function(){alert('ok')}, function(){alert('cancel')}).modal('show');
или при отсутствии логики для отмены:
bootbox_confirm("my message", function(){alert('ok')}).modal('show');
Ответ 2
Это должно работать для вас, используя Bootbox 4.x.x и Bootstrap 3.x.x:
var box = bootbox.dialog({
message: '',
title: '',
buttons: {},
show: false
});
box.on("shown.bs.modal", function() {
alert('it worked!');
});
box.modal('show');
или вот так:
$(document).on("shown.bs.modal", function (event) {...});
Ответ 3
вы можете сделать вот так:
var dialog = bootbox.dialog("foo", [], {show: false});
dialog.on("shown", function() {
//
});
dialog.modal("show");