JQuery предотвратить по умолчанию кажется застрял и требует дополнительного щелчка - PullRequest
0 голосов
/ 04 декабря 2011

Я пишу плагин jquery для отображения диалогового окна jquery ui, когда по ссылкам щелкают, чтобы предоставить диалоговое окно подтверждения перед переходом по ссылке.

Проблема, с которой я сталкиваюсь, заключается в том, что при закрытии диалога с помощьюПри нажатии кнопки «Да» плагин использует $(element).trigger( 'click' ); для запуска события click для исходного элемента привязки.

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

Плагин используется следующим образом $('a').submitConfirm();

Вот плагин

;(function ( $, window, document, undefined )
{
    var pluginName = "submitConfirm";

    var Plugin = function( element )
    {
        var confirmed = false;

        var dialog = $( '<div style="display:none;">' )
        .html( 'Visit this link?' )
        .dialog(
        {
            modal: true,
            title: 'Visit Link?',
            autoOpen: false,
            buttons :
            [
               {
                    text: 'Yes',
                    click: function( event )
                    {
                        confirmed = true;
                        dialog.dialog( "close" );
                        $(element).trigger( 'click' );
                    }
                },
                {
                    text: 'No',
                    click: function( event )
                    {
                        confirmed = false;
                        dialog.dialog( "close" );
                    }
                }
            ]
        });

        $(element).bind( 'click',
        function( event )
        {
            if ( ! confirmed )
            {
                dialog.dialog( "open" );
                event.preventDefault();
            }
        });
    };

    // Init the plugin
    $.fn[pluginName] = function( options )
    {
        return this.each(function ()
        {
            // Prevent re-instantiation
            if ( !$.data(this, 'plugin_' + pluginName) )
            {
                $.data(this, 'plugin_' + pluginName,
                new Plugin( this, options ));
            }
        });
    };
})( jQuery );

1 Ответ

1 голос
/ 04 декабря 2011

Вы должны передать функции, содержащей то, что вы хотите сделать, плагину.
Добавьте эту строку, когда вы устанавливаете параметры по умолчанию для плагина внизу вашего JavaScript.

$(function()
{
    $('a').submitConfirm(
    {
        html: 'Are you sure?',
        onConfirm: function(event){ // Do what you want in this function.
            alert('Confirmed.. Now what?.. Redirect?.. ?? ');
            // window.location = $(this).attr('href'); // redirect
                },
        beforeShow: function( dialog )
        {
            dialog.html( 'visit google?' );
        }
    });
});

Обновление
Проверьте это JSfiddle -> http://jsfiddle.net/kmTtQ/6/
Я изменил строки ниже. По сути, мы хотим добавить событие .click к элементу, а затем нажать .trigger('click').

if ( confirmed ){
    console.log( element, elementEvent, event.isDefaultPrevented );
    // .on() = jQuery 1.7+, for < 1.7 use .bind or .live. Aliases of .on() as of 1.7
    $(element).on('click', function(){ // bind our element with the click
        event.view.window.location = element.href; // on click redirect
    });

    $(element).trigger( 'click' ); // We want to trigger the ^ click event ^
}
...