我正在使用 jQuery mobile,目前使用下面的代码动态构建菜单。我现在需要为菜单项创建实际页面作为下一步。我一直在研究 jQuery Mobile 和动态页面生成,并认为这是我“可以”用来实现这一目标的东西。我已经阅读了动态页面生成文档,但不明白如何将其放入我当前的代码中,或者即使它适合我需要实现的目标。
我你可以在下面看到,当我为主页构建菜单输出时,我已经有了 ID 和页面名称等,有人可以向我展示我现在如何使用 jquery 为这些菜单项动态构建所需的 html 页面的示例吗?谢谢你。
$.each(siteData["pages"], function(i,v) {
$.mobile.activePage.find('[data-role=content]').append('' +
'<a href='+ v["id"] + ' data-role="button">' + v["name"] + '</a>').trigger('create');
// NOW I HAVE THE MENU LETS CREATE THE ACTUAL PAGES INSIDE HERE TOO
});
在 navlist 中创建的当前标记菜单项:
<div data-role="page" id="index">
<div data-theme="a" data-role="header">
</div>
<div data-role="content" class="navlist">
</div>
<div data-role="footer">
</div><!-- /footer -->
</div>
所以现在对于每个项目,我需要使用 jquery 为每个项目生成标记。
更新:所以根据建议我尝试了这样的事情,但它不起作用。
$.each(siteData["pages"], function(i,v) {
$.mobile.activePage.find('[data-role=content]').append('' +
'<a href='+ v["id"] + ' data-role="button">' + v["name"] + '</a>').trigger('create');
// Prepare your page structure
var newPage = $("<div data-role='page' id=v[id]><div data-role=header>" +
"<a data-iconpos='left' data-icon='back' href='#' data-role='button' " +
"data-rel='back'>Back</a><h1>Dynamic Page</h1></div><div data-role=content>Stuff here</div></div>");
// Append the new page info pageContainer
newPage.appendTo($.mobile.pageContainer);
// Move to this page by ID '#page'
$.mobile.changePage('#'+v["id"]);
});