The client is making a request to the server.
I need to take part of that request, and make the form button work with Ajax.
This piece of code works perfectly for links:
var pagination_render = function() {
var pagination = $('.pagination a');
pagination.each(function() {
$(this).click(function(event) {
load_server(this.href, '.houseindex');
return false;
});
});
};
pagination_render();
I tried numerous things for making the Ajax button work, and this is one of the tries:
var contact_user = function () {
$('.expanded').find('#submit').each(function() {
$(this).unbind('click');
});
$('.expanded').each(function() {
$(this).find('#submit').click(function(event) {
form_submit($(this).parent(), '.contactuser .msg');
return false;
});
});
}
Whenever there is a successful Ajax call, it goes through all of the expanded items, and then binds a click event.
Now, sometimes this code works, and sometimes it doesn’t.. When it doesn’t work, it disables other events (toggle links) I have set up.
It seems as if I need to wait a few ms for it to load the component into the DOM.. Do I?
So I get that when you call
contact_useryou:#submit. You should only have one id in a single page. Therefore you only need to use$('#submit').each(...)or if you have several submit buttons in the page either use a class if there are several submit buttons inside an.expandeditem or just use$('.expanded :submit')$('.expanded :submit')or if you truly only have one button with an id ofsubmit(quite confusing). Go with$('#submit').In conclusion:
the
:submitselector will select all<input type="submit" />.