Tiaw Tiaw - 5 months ago 27
Ajax Question

Ajax request duplicate on page call back

I made an ajax script that call the page asked in a

div in php, so if i call the project.html page, the request working well, calling the page and the
associate but if i try to call back my home page the requests are duplicate:

enter image description here

There is my php function:

<?php $d="pages/" ; if(isset($_GET[ 'p'])){ $p=strtolower($_GET[ 'p']); if(preg_match( "/^[a-z0-9\-]+$/",$p) && file_exists($d.$p. ".html")){ include $d.$p. ".html"; } else{ include $d. "404.html"; } } else{ include $d. "home.html"; } ?>

and this is my ajax request:

var afficher = function(data, page) {

$('#container').fadeOut(500, function() {

$('#container').fadeIn(100, function() {});


var loadPage = function(page, storeHistory) {
if (typeof storeHistory === 'undefined') {
storeHistory = true;

url: 'pages/' + page,
cache: false,
success: function(html) {
afficher(html, page);
if (storeHistory === true) {
'key': 'value',
'url': page
}, '', page);
error: function(XMLHttpRequest, textStatus, errorThrown) {
afficher('erreur lors du chagement de la page');

return false;

window.addEventListener('load', function() {
setTimeout(function() {
window.addEventListener('popstate', function(e) {
if (e.state === null) {
} else {
loadPage(e['state']['url'], false);
}, 0);

$(document).ready(function() {
$('.project a').on('click', function(e) {
var page = $(this).attr('href');
return false;

$('#menu a').on('click', function() {
var page = $(this).attr('href');
return false;


How can i fix the problem of multiple request when i call my home page ?


The problem here is somehow the event is getting added again and again. One temperary solution and suggested solution will be to abort the previous ajax everytime you call another ajax. So it can be:

var lastRequest = null;
lastRequest = $.ajax({
//your code

So, by this way there will only one active ajax at a time.

Hope that helps.