如何将提交函数添加到js Onclick函数中

时间:2014-07-23 01:09:31

标签: javascript html

我试图在点击按钮时触发一个网址,当点击删除按钮时它会触发JS警报,但它没有传递链接,而是删除按钮。一旦确认警报,如何让它处理链接?

js code

<script>
$(function() {
$('#demo').confirmOn('click', function() {
$(this).remove();
});
});
</script>

HTML

<a href="index.php?page=test:delete&item_id={item_id}" id="demo">
<input type="button" class="log_button" value="Delete"/>

确认代码..

(function($) {
var confirmOn = $.confirmOn = {};

confirmOn.providedOptions = {};

confirmOn.defaultSettings = {
    questionText: 'Are you sure?',
    classPrepend: 'confirmon',
    textYes: 'Yes',
    textNo: 'No'
};

confirmOn.overrideDefaultSettings = function(settings) {
    confirmOn.defaultSettings = $.extend({}, confirmOn.defaultSettings, settings);
};

confirmOn.setOptions = function($element, options) {
    options = $.extend({}, confirmOn.defaultSettings, options);
    $element.data('confirmon', {
        options: options
    });
};

confirmOn.createOverlay = function($element) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    return $('<div/>').addClass(classPrepend + '-overlay').hide().appendTo('body');
};

confirmOn.showOverlay = function($element) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    $('.' + classPrepend + '-overlay').fadeIn();
};

confirmOn.deleteOverlay = function($element) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    $('.' + classPrepend + '-overlay').fadeOut(function(){
        $(this).remove();
    });
};

confirmOn.createBox = function($element) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    var questionText = $element.data('confirmon').options.questionText;
    var textYes = $element.data('confirmon').options.textYes;
    var textNo = $element.data('confirmon').options.textNo;

    var $box = $('<div/>').addClass(classPrepend + '-box').hide().appendTo('body');
    $('<p class="' + classPrepend + '-content"/>')
        .html(questionText)
        .appendTo($box);
    $('<button class="' + classPrepend + '-button ' + classPrepend + '-button--yes"/>')
        .html(textYes)
        .appendTo($box);
    $('<button class="' + classPrepend + '-button ' + classPrepend + '-button--no"/>')
        .html(textNo)
        .appendTo($box);

    $('.' + classPrepend + '-button').on('keydown', function(e){
        if (e.which === 9) { //Tab key
          e.preventDefault(); 
          $('.' + classPrepend + '-button').not(this).focus();
        } 
    });

};

confirmOn.showBoxAndFocusNo = function($element) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    $('.' + classPrepend + '-box').fadeIn(function(){
        $(this).children('button').eq(1).focus();
    });
};

confirmOn.deleteBox = function($element) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    $('.' + classPrepend + '-box').fadeOut(function(){
        $(this).remove();
    });
};

$.confirmOn.handleEscKey = function($element) {
    $(document).on('keydown.confirmon.close', function(e){
        if (e.which === 27) { //Esc key
            $.confirmOn.deleteOverlay($element);
            $.confirmOn.deleteBox($element);
            $(document).off('keydown.confirmon.close');
        }
    });
}

confirmOn.convertArguments = function(options, events, selector, data, handler) {
    if (typeof options === 'object') {
        $.each(options, function(key, val) {
            if (typeof val === 'string') { //Options provided so shift all args to left
                confirmOn.providedOptions = options;

                options = events;
                events = selector;
                selector = data;
                data = handler;
                return false;
            } else { //No options
                confirmOn.providedOptions = {};
            }
        });
    } else {
       confirmOn.providedOptions = {}; 
    }

    if (selector == null && data == null && handler == null) {
        //(events[S], handler)
        selector = events;
        events = options;
    } else if (data == null && handler == null) {
        //(events[S], selector, handler)
        //(events[S], data, handler)
        data = selector;
        selector = events;
        events = options;
    } else {
        handler = data;
        data = selector;
        selector = events;
        events = options;
    }

    if (typeof events === 'object') {
        //Implementation .on( events [, selector ] [, data ] )
        return {
            events: events,
            selector: selector,
            data: data
        };
    } else {
        //Implementation .on( events [, selector ] [, data ], handler(eventObject) )
        return {
            events: events,
            selector: selector,
            data: data,
            handler: handler
        };
    }


};

$.confirmOn.attachHandlers = function($element, handler, event) {
    var classPrepend = $element.data('confirmon').options.classPrepend;
    $('.' + classPrepend + '-box button').eq(0).on('click', function(){
        $.confirmOn.deleteOverlay($element);
        $.confirmOn.deleteBox($element);
        handler.call($element.get(), event, true); //Call the handler function. the TRUE parameter indicates that the user pressed the YES button

    });

    $('.' + classPrepend + '-box button').eq(1).on('click', function(){
        $.confirmOn.deleteOverlay($element);
        $.confirmOn.deleteBox($element);
        handler.call($element.get(), event, false); //Call the handler function. the FALSE parameter indicates that the user pressed the YES button

    });

 };

 $.fn.confirmOn = function(options, events, selector, data, handler) {
    var userHandler;
    if (typeof events === 'function') {
        userHandler = events;
        events = confirmHandler;
    } else if (typeof selector === 'function') {
        userHandler = selector;
        selector = confirmHandler;
    } else if (typeof data === 'function') {
        userHandler = data;
        data = confirmHandler;
    } else if (typeof handler === 'function') {
        userHandler = handler;
        handler = confirmHandler;
    }

    var $element = $(this);
    var onArgs = $.confirmOn.convertArguments(options, events, selector, data, handler);
    $.confirmOn.setOptions($element, $.confirmOn.providedOptions);

    $element.on(onArgs.events, onArgs.selector, onArgs.data, onArgs.handler);

    function confirmHandler(event) {
        event.preventDefault();            
        $.confirmOn.createOverlay($element);
        $.confirmOn.showOverlay($element);
        $.confirmOn.createBox($element);
        $.confirmOn.showBoxAndFocusNo($element);
        $.confirmOn.handleEscKey($element);
        $.confirmOn.attachHandlers($element, userHandler, event);            
    };

};

}(jQuery));

2 个答案:

答案 0 :(得分:1)

使用confirm()

试试这个:

$("#demo").click(function() {
    var confirm1 = confirm('Dialogue');
    if (confirm1) {
      $(this).remove();
      return true;
    } else {
      return false;
    }
});

<强>更新

$(function () {
    $('#demo').confirmOn('click', function (e, confirmed) {
        if (confirmed) { // Clicked yes
            document.location.href= $(this).attr('href');
            $(this).remove();
            $('#msg_button_1').remove();
        } else { // Clicked no
            $('#msg_button_1').fadeIn();
        }
    });
});

<强> JSFiddle Demo

答案 1 :(得分:0)

被修改

<script>
    $(function() {
         $('.log_button').confirmOn('click', function(e, confirmed) {
             if(confirmed){
                //$('#demo').remove();
                $('#demo').click();
             }else{
                alert("not go");
             }
         });
    });
</script>

这是你真正想做的事情吗?单击按钮,然后转到链接?

相关问题