custom choices in javascript confirm dialog

2019-01-06 22:29发布

How to write a confirm dialog in javascript with custom choices?

Instead of just "Ok" and "Cancel", I would like to have for example "This" "That" and "Other".

4条回答
甜甜的少女心
2楼-- · 2019-01-06 22:36

You could ask the user for an answer using:

var userChoice = prompt("Question");

You could loop that sentence until the user enters an answer within the valid ones.

查看更多
一纸荒年 Trace。
3楼-- · 2019-01-06 22:45

In short, you can't.

You might want to consider looking into using something like a jQuery UI dialog instead.

查看更多
我命由我不由天
4楼-- · 2019-01-06 22:45

You can't. Use some javascript UI (jQuery UI, YUI, Mootools) library and mimic a dialog you need.

查看更多
beautiful°
5楼-- · 2019-01-06 22:54
// custom Confirm builder
function OnConfirm(text, func) {

    var _confirm = $('<div/>').addClass('confirm');
    _confirm.append($('<h2/>').text(text));

    _confirm.append('<br/><br/>');

    var _btnCancel = $('<input/>').attr('type', 'button').val('cancel')
        .bind('click', function () {
            $(this).parent('.confirm').hide();
            func(false);
        });

    var _btnApply = $('<input/>').attr('type', 'button').val('OK')
        .bind('click', function () {
            $(this).parent('.confirm').hide();
            func(true);
        });

    _confirm.append(_btnCancel);
    _confirm.append(_btnApply);
    $('body').append(_confirm);
}

$(function () { // documen.loaded
    $('#testLink').click(function (e) {
        e.preventDefault(); ;
        var _href = $(this).attr('href');
        var _title = $(this).attr('title');
        // call custom confirm function with callback function
        OnConfirm(_title, function (_isContinue) {               
                if (_isContinue) {
                    location.href = _href;
                }
            }
        );
    });
});
查看更多
登录 后发表回答