Не скрывайте загрузчик, пока страница полностью не загрузится в jquery mobile
Я пытаюсь показать виджет загрузки страницы, пока страница не загрузится полностью, после этого она должна скрыться... и делать этот процесс каждый раз, когда я нажимаю любой якорь для передачи на следующую страницу..
Поддержка у меня есть три страницы...
<div data-role="page" id="home">....</div>
<div data-role="page" id="about">....</div>
<div data-role="page" id="contact">....</div>
Скрипт по этому я использую:-
$(document).on("pagecreate", function(event) {
//alert("Take It Show");
$( ".ui-loader" ).loading( "hide" );
});
Можно ли добавить переход как data-transition="slide"
на любой якорь или использовать data-ajax="false"
в этом...??
1 ответ
Решение
Рабочий пример: http://jsfiddle.net/Gajotres/Zr7Gf/
В основном Javascript снизу это все, что вам нужно.
HTML:
<!DOCTYPE html>
<html>
<head>
<title>jQM Complex Demo</title>
<meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; minimum-scale=1.0; user-scalable=no; target-densityDpi=device-dpi"/>
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.css" />
<script src="http://code.jquery.com/mobile/1.2.0/jquery.mobile-1.2.0.min.js"></script>
</head>
<body>
<div data-role="page" id="index">
<div data-theme="a" data-role="header">
<h3>
First Page
</h3>
<a href="#second" class="ui-btn-right">Next</a>
</div>
<div data-role="content">
</div>
<div data-theme="a" data-role="footer" data-position="fixed">
</div>
</div>
<div data-role="page" id="second">
<div data-theme="a" data-role="header">
<h3>
First Page
</h3>
<a href="#index" class="ui-btn-left">Back</a>
</div>
<div data-role="content">
</div>
<div data-theme="a" data-role="footer" data-position="fixed">
</div>
</div>
</body>
</html>
Javascript:
$(document).on('pagebeforecreate', '[data-role="page"]', function(){
var interval = setInterval(function(){
$.mobile.loading('show');
clearInterval(interval);
},1);
});
$(document).on('pageshow', '[data-role="page"]', function(){
var interval = setInterval(function(){
$.mobile.loading('hide');
clearInterval(interval);
},300);
});