Проблема с кодированием jQuery
Вопрос
Эй, ребята, я работаю над программой обновления "статуса".Это работает, есть только одна проблема, после отправки статуса мне приходится вручную перезагружать страницу, чтобы скрипт снова заработал.Вы можете мне помочь, пожалуйста?Вот код:
<script language="javascript">
$(document).ready(function(){
$("form#status_form").submit(function(){
var s_autor = $('#s_autor').attr('value');
var s_status = $('#s_status').attr('value');
$.ajax({
type: "POST",
url: "/admin/request.php",
data: "s_autor="+ s_autor +"& s_status="+ s_status,
success: function(){
$('#show').load("/admin/request.php").fadeIn("slow", function(){
setTimeout(function(){
$(function() {
$("#show").fadeTo("slow", 0.01, function(){
$(this).slideUp("slow", function() {
$(this).remove();
});
});
});
}, 2000);
});
},
});
return false;
});
});
</script>
Итак, вы знаете, как закодировать это, чтобы можно было повторять скрипт так часто, как я нажимаю на кнопку отправки?
Кстати, вот HTML-форма:
<form id="status_form" method="post" action="request.php" onsubmit="return false;">
<input type="text" id="s_autor" name="s_autor" value="<?= $user_id; ?>" style="display: none;" /><input type="text" id="s_status" name="s_status" value="Statusnachricht" /><input type="submit" value="" class="submit" id="status_submit" />
</form>
Решение
Похоже, что после вашего первого вызова этого кода вы уничтожаете #show, и, таким образом, в следующий раз #show больше не будет?Я собираюсь добавить несколько комментариев к вашему коду, чтобы проверить, правильно ли я это понимаю:
success: function() {
// File has been successfully posted to request.php
// We are now going to GET the contents of request.php (ignoring any response from the previous POST)
// Also note, should probably put remainder of code in a callback to "load", so we can be sure it has had a chance to load!...
$('#show').load("/admin/request.php").fadeIn("slow", function(){
setTimeout(function(){
$(function() {
$("#show").fadeTo("slow", 0.01, function(){
$(this).slideUp("slow", function() {
// Note! #show is being removed from the document here. It won't be available for future events.
$(this).remove();
});
});
});
}, 2000);
});
},
Удачи вам!
Редактировать Посмотрев на это еще немного, я заметил, что вы создаете событие document "ready" после вашего setTimeout?
Я пытаюсь понять, какого эффекта вы хотите.Похоже, вы хотите, чтобы что-то исчезло после завершения загрузки (в #show
div), подождите несколько секунд, затем снова отключите его?(Ваш slideUp
воздействует на выцветший элемент, поэтому эффект не будет виден.)
Как насчет чего-то вроде этого?
success: function() {
// File has been successfully posted to request.php
// We are now going to GET the contents of request.php (ignoring any response from the previous POST)
$('#show').load("/admin/request.php", function() {
$(this).fadeIn("slow", function() {
setTimeout(function() {
$("#show").fadeOut("slow", function() {
// don't remove #show. Just empty it for using again next time.
$(this).empty()
});
}, 2000);
});
});
},