我正在努力让持久的Jquery Mobile导航栏页脚工作。我希望用javascript(它是用于PhoneGap应用程序)动态绘制它,而不是使用PHP来模板页脚。
以下内容改编自: http://the-jquerymobile-tutorial.org/jquery-mobile-tutorial-CH21.php
然而,jquery样式没有应用于第2页和第3页。就像$(“#navbar”)。navbar()没有为这些页面调用或过早调用。
任何人都可以帮我解决我可能出错的地方吗?或者指向一个具有动态持久导航栏的代码示例,最好使用活动按钮持久性?
<!DOCTYPE html>
<html>
<head>
<meta name=viewport content="user-scalable=no,width=device-width" />
<link rel=stylesheet href=jquery.mobile.css />
<script src=lib/jquery.js></script>
<script src=lib/jquery.mobile.js></script>
</head>
<body>
<div data-role=page id=page1>
<div data-role=header>
<h1>1</h1>
</div>
<div data-role=content>
<p> Window content </p>
</div>
</div>
<div data-role=page id=page2>
<div data-role=header>
<h1>2</h1>
</div>
<div data-role=content>
<p> Window content </p>
</div>
</div>
<div data-role=page id=page3>
<div data-role=header>
<h1>3</h1>
</div>
<div data-role=content>
<p> Window content </p>
</div>
</div>
</body>
</html>
<script>
var html = "";
html += "<div data-role=footer data-position=fixed>";
html += "<h1> Footer part </h1>";
html += "<div id=navbar>";
html += "<ul>";
html += "<li><a href=#page1 data-icon=refresh>Refresh</a></li>";
html += "<li><a href=#page2 data-icon=info>Help</a></li>";
html += "<li><a href=#page3 data-icon=delete>Close</a></li>";
html += "</ul>";
html += "</div>";
html += "</div>";
$("#page1").append (html);
$("#page2").append (html);
$("#page3").append (html);
$("#navbar").navbar();
</script>
<script>
$("li").bind ("click", function (event)
{
alert ($(this).find ("a").text ());
});
</script>
答案 0 :(得分:0)
在您的代码中,navbar()
对我来说非常奇怪。因为我从未在jquery移动官方文档中看到过这些方法。还有一件事,你从来没有提到listview div元素的data-role="navbar"
。
您可以使用noramal jquery .append()
方法动态追加jquery navbar。
我将在jquery中为您提供动态导航栏的示例代码。它会解决你的问题。
$navbar="";
$navbar+="<div data-role='navbar'>";
$navbar+="<ul><li><a href='a.html' class='ui-btn-active ui-state-persist'>One</a></li>";
/*This class="ui-btn-active ui-state-persist" is to highlight the first tab*/
$navbar+="<ul><li><a href='b.html'>Two</a></li>";
$navbar+="<li><a href='c.html'>Three</a></li></ul></div>";
$("#page1").append ($navbar); /*First append to page 1 of the footer*/
$("#page1").trigger("pagecreate"); /*To refresh the page and load the dynamic append navbar*/
在第2页和第3页的按钮点击中执行相同的过程会更改class='ui-btn-active ui-state-persist'
各个页面。