Javascript не перенаправляет, а время в приложении Django остается прежним. Как решить эту проблему?
Привет всем, я пытаюсь создать веб-приложение с использованием django и js. Это своего рода чат приложение есть комнаты и каждая комната имеет время после того, как время закончилось. Я хочу удалить комнату. Пока я делаю тест, я понимаю, если один пользователь в комнате, другой пользователь на странице списка, комната не удаляется, когда 1 пользователь в комнате и другой странице списка. Время остается 1 секунда Как можно решить эту проблему. Можете ли вы помочь мне? Спасибо.
room_detail_page
function updateRemainingTime() {
// Sunucuya AJAX isteği gönder
var xhr = new XMLHttpRequest();
xhr.open('GET', '/remaining-time/' + roomName + '/', true);
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
var remainingTime = JSON.parse(xhr.responseText);
// Kalan süreyi güncelle
document.getElementById('remaining-time').textContent = remainingTime.minutes + ':' + remainingTime.seconds;
if (remainingTime.minutes <= 0 && remainingTime.seconds <= 0) {
deleteRoom(roomName);
}
}
};
xhr.send();
}
function deleteRoom(roomId) {
var xhr = new XMLHttpRequest();
xhr.open('POST', '/delete-room/' + roomId + '/', true);
xhr.setRequestHeader('X-CSRFToken', '{{ csrf_token }}');
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
window.location.href = '/home';
location.reload()
}
};
xhr.send();
}
setInterval(updateRemainingTime, 1000);
room_list_page
function updateRemainingTime(roomId) {
// Sunucuya AJAX isteği gönder
var xhr = new XMLHttpRequest();
xhr.open('GET', '/remaining-time/' + roomId + '/', true);
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
var remainingTime = JSON.parse(xhr.responseText);
// Kalan süreyi güncelle
var remainingTimeElement = document.getElementById('remaining-time-' + roomId);
remainingTimeElement.textContent = remainingTime.minutes + ':' + remainingTime.seconds;
if (remainingTime.minutes <= 0 && remainingTime.seconds <= 0 ) {
// If remaining time is 0 or negative, delete the room
deleteRoom(roomId);
}
}
};
xhr.send();
}
// Belirli aralıklarla her oda için zamanı güncelle
function deleteRoom(roomId) {
// Sunucuya AJAX isteği gönder
var xhr = new XMLHttpRequest();
xhr.open('POST', '/delete-room/' + roomId + '/', true);
xhr.setRequestHeader('X-CSRFToken', '{{ csrf_token }}'); // Add CSRF token if needed
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
location.reload()
}
};
xhr.send();
}
room_ids.forEach(function(roomId) {
setInterval(function() { updateRemainingTime(roomId); }, 1000); // Her saniyede bir güncelle
});
api.py
def remaining_time_api(request, room_id):
room = Room.objects.get(id=room_id)
remaining_time = room.remaining_time()
seconds = remaining_time.seconds % 60
minutes = (remaining_time.seconds // 60) % 60
return JsonResponse({'minutes': minutes, 'seconds': seconds})
def delete_room(request, room_id):
room = get_object_or_404(Room, id=room_id)
room.delete()
return redirect('/home')