In the following page, with Firefox the remove button submits the form, but the add button does not.
How do I prevent the remove
button from submitting t
Set the type on your buttons:
...that'll keep them from triggering a submit action when an exception occurs in the event handler. Then, fix your removeItem()
function so that it doesn't trigger an exception:
function removeItem() {
var rows = $('form tr');
if ( rows.length > 2 ) {
// change: work on filtered jQuery object
rows.filter(":last").html('');
$('form :hidden:last').val('');
} else {
alert('Cannot remove any more rows');
}
}
Note the change: your original code extracted a HTML element from the jQuery set, and then tried to call a jQuery method on it - this threw an exception, resulting in the default behavior for the button.
FWIW, there's another way you could go with this... Wire up your event handlers using jQuery, and use the preventDefault() method on jQuery's event object to cancel the default behavior up-front:
$(function() // execute once the DOM has loaded
{
// wire up Add Item button click event
$("#AddItem").click(function(event)
{
event.preventDefault(); // cancel default behavior
//... rest of add logic
});
// wire up Remove Last Item button click event
$("RemoveLastItem").click(function(event)
{
event.preventDefault(); // cancel default behavior
//... rest of remove last logic
});
});
...
This technique keeps all of your logic in one place, making it easier to debug... it also allows you to implement a fall-back by changing the type
on the buttons back to submit
and handling the event server-side - this is known as unobtrusive JavaScript.