JavaScript приостановка сценария изменяет порядок внешнего вида
-
09-12-2019 - |
Вопрос
У меня есть следующий скрипт:
posting();
pause(time);
postSent(postUrl, fields);
function postSent(postUrl, fields)
{
$.ajax( {
url : postUrl,
type : "POST",
data : fields,
cache : false,
error : function(xhr, textStatus, errorThrown) {
var answer = xhr.responseText;
answer = answer.split(":");
answer = answer[0].replace(/}/g,"").replace(/{/g,"").replace(/"/g,"");
if (answer == "id")
{
isPostSent = true;
}
else
{
isPostSent = false;
}
}
});
}
function pause(milliseconds) {
var dt = new Date();
while ((new Date()) - dt <= milliseconds) { /* Do nothing */ }
}
function posting()
{
var table = '';
table += '<table border="0" rules="none" cellpadding="5" style="z-index:+10; position:fixed; top:35%; left:35%; box-shadow: 0px 0px 5px 5px #888888;" rules="none" border="0" bgcolor="#edeff4">';
table += '<td align="center">';
table += '<img src="images/loading.gif" id="post_status_image">';
table += '</td>';
table += '<tr >';
table += '<td align="center">שולח הודעה, אנא המתן...</td>';
table += '</tr>';
table += '<tr>';
table += '<td align="center" id="post_status"></td>';
table += '</tr>';
table += '<tr >';
table += '<td align="center" ><img id="post_close" src="images/close1.png" onclick="closePop()" style="visibility:hidden;"></td>';
table += '</tr>';
table += '</table>';
document.getElementById('post').innerHTML = table;
}
.
Время установлено на 3000 милисекунды. Моя проблема заключается в том, что я хочу выложить () функцию, чтобы показать таблицу на экране (его вид экрана «Загрузка»), а затем приостановить сценарий. На самом деле, из какой-то причины сценарий первого паузы, и только после того, как он заканчивается, он покажет мне экран загрузки ... Как прийти?
Решение
Браузеры запускают JavaScript и рендурируйте все на одном потоке.Таким образом, все три функции JS будут завершаться до обновления страницы.Вот почему вы должны никогда не реализуйте функцию паузы в JS, основанные на цикле и проверке времени.Вместо этого вам нужно использовать setTimeout()
и поместить любой код, который необходимо запустить после паузы в обратном вызове, который вы передаете для setTimeout()
.
Использование вашего примерного кода:
.posting();
setTimeout(function() {
postSent(postUrl, fields);
}, 3000);
Другие советы
Нет функции сна или паузы в родном JavaScript.Но мы можем достичь вроде этого.
function sleep(milliseconds) {
var start = new Date().getTime();
for (var i = 0; i < 1e7; i++) {
if ((new Date().getTime() - start) > milliseconds){
break;
}
}
}
.
Я создал Widdle AT: http://jsfiddle.net/6dqbp/
Сценарий, взятый из: http://www.phpied.com/sleep-in-JavaScript /
Я нашел этот URL после ответа.Может быть полезным.