4

我正在尝试编写自己的方法来调用 BootstrapDialog 并创建一个确认弹出窗口。如果用户选择“确认”,则该方法将返回 true 并继续调用 jsf 操作。我到目前为止的代码:

 /**
 * Confirm window
 *
 * @param {type} message
 * @param {type} callback
 * @returns {undefined}
 */
BootstrapDialog.confirmation = function(title, message) {

    var callback = function(result) {
        console.log(result);
        return result;
    };

    var b = new BootstrapDialog({
        title: title,
        message: message,
        closable: false,
        data: {
            'callback': callback
        },
        buttons: [{
                label: 'Cancel',
                action: function(dialog) {
                    typeof dialog.getData('callback') === 'function' && dialog.getData('callback')(false);
                    dialog.close();
                }
            }, {
                label: 'Continue',
                cssClass: 'btn-primary',
                action: function(dialog) {
                    typeof dialog.getData('callback') === 'function' && dialog.getData('callback')(true);
                    dialog.close();
                }
            }]
    }).open();


    return callback;


};

我这样称呼js:

<h:commandButton type="button" value="Exit" action="myaction" styleClass="btn btn-default" onclick="return BootstrapDialog.confirmation('Data unsaved', 'Are you sure you want to continue');"/>

对话框弹出就好了,问题是它没有返回真/假。我在这个例子之后建模了我的 js:http: //nakupanda.github.io/bootstrap3-dialog/

4

3 回答 3

2

我不认为你真的想延长BootstrapDialog. 而且我不会期望对话框返回任何内容,因为它将异步操作(它必须等待用户通过按下按钮来操作。)所以您需要通过它的回调与它进行交互。

bootstrap3-dialog除了我刚刚在其 Github 页面上看到的内容之外,我并不熟悉,因此它可能会为您提供额外的回调或事件来更整洁地执行此操作。但我认为这将大致完成你所追求的:

function letUserExit() {
    // Add code here to redirect user where she expects to go 
    // when pressing exit button or to submit a form or whatever.
}

var exitConfirmDialog = new BootstrapDialog({
    title: 'Data unsaved',
    message: 'Are you sure you want to continue?',
    closable: false,
    buttons: [
        {
            label: 'Cancel',
            action: function(dialog) {
                dialog.close();
            }
        },
        {
            label: 'Continue',
            cssClass: 'btn-primary',
            action: function(dialog) {
                letUserExit();
            }
        }
    ]
});

// Add event to invoke dialog to your exit button here
$('button.exit').on('click', function() {
    // Show or open? Not quite sure what difference is. Use the one
    // that's most appropriate.
    exitConfirmDialog.show();

    // Stop any events (like a form being submitted or user being
    // redirected.) Need to wait until user responds to modal and
    // have event take place then.
    return false;
});
于 2014-08-03T04:16:46.373 回答
0

我是 Bootstrap 的新手,两个小时前才发现 bootstrap-dialog,所以我的回答只值它的价值......(法语说,它是如何翻译成英文的??)

我很快遇到了一个类似的问题:如何在点击提交按钮时使用漂亮的引导程序确认来替换丑陋的 javascript 确认 API?...

正如 KLenwel 所说,confirm 是一个同步 API,bootstrap-dialog 是一个异步 API。您的线程只是不等待用户回答回发(或不回发。)

我使用辅助按钮弹出确认对话框。真正的提交按钮被隐藏。Bootstrap 对话框确认触发提交按钮的单击,同时保留 javascript 提交处理程序和发送到服务器的 http 标头。

此代码示例是 ASP.Net Webform 页面的摘录,使用数据绑定为不可见按钮提供唯一的 css 类名称,以便可以通过 javascript 对话框回调轻松触发它。我确实使用了 CssClass 属性,而不是使用 id 属性。这只是出于 ASP.Net 的原因。

<asp:Button style="display: none" runat="server" CssClass='<%# Eval( "Id" ) %>' OnCommand="Delete" CommandName='<%# Eval( "Id" ) %>' />
<input type="button" class="btn btn-danger" value="Delete" onclick="BootstrapDialog.confirm('Delete?', function(ok) {if(ok) $('.<%# Eval( "Id" ) %>').click(); } )" />

同样的事情,在纯 HTML 中,ASP.Net WebForms 独立(使用控件的 id):

<input type="submit" style="display: none" id="TheSubmitButton" onclick="alert('ok, submit will be fired');" />
<input type="button" title="Delete" data-placement="bottom" class="btn btn-danger" value="Delete" onclick="BootstrapDialog.confirm('Delete?', function(ok) {if(ok) $('#TheSubmitButton').click(); } )" />
于 2015-02-02T14:49:11.503 回答
0

我有同样的问题,但我使用 eval() 解决了。功能是

function showConfirmBootstrap(type,title,mesagge, myFunction){

    BootstrapDialog.confirm({
        size: "size-small",
        type: "type-"+type, 
        title: title,
        message: mesagge,
        cssClass: 'delete-row-dialog',
        closable: true,
        callback: function(result) {
            if(result) { eval(myFunction); }
        }
    });
}

当结果为真时,应用程序将执行 myFunction。你怎么看,myFunction 是 main 函数中的一个参数。

您可以发送类型引导程序、标题和消息作为参数。

一个例子是:

showConfirmBootstrap("danger","Error","Do you want do this function?", "alert(5)")
于 2016-03-08T20:41:20.943 回答