First.html
<!DOCTYPE HTML> <html> <head> <title>Test1</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <link rel="stylesheet" href="http://code.jquery.com/mobile/1.3.1/jquery.mobile-1.3.1.min.css" /> <script src="http://img.558idc.com/uploadfile/allimg/210615/2123021V5-0.jpg"></script> <script src="http://img.558idc.com/uploadfile/allimg/210615/2123025J5-1.jpg"></script> <script src="../scripts/common.js"></script> </head> <body> <div data-role="page" id="first"> <h1 style="background: red">Swipe 1</h1> <a href="second.html">Click</a> </div> </body> </html>
Second.html
<!DOCTYPE html> <html> <head> <title>Test2</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <link rel="stylesheet" href="http://code.jquery.com/mobile/1.3.1/jquery.mobile-1.3.1.min.css" /> <script src="http://img.558idc.com/uploadfile/allimg/210615/2123021V5-0.jpg"></script> <script src="http://img.558idc.com/uploadfile/allimg/210615/2123025J5-1.jpg"></script> <script src="../scripts/common.js"></script> </head> <body> <div data-role="page" id="second"> <div data-role="header"> <h1>jQuery Mobile</h1> </div> <div data-role="content"> <a href="third.html">Click</a> </div> <div data-role="footer"> <h4>www.jboss.org/developer</h4> </div> </div> </body> </html>
third.html
<!DOCTYPE html> <html> <head> <title>jQuery Mobile Template</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1" /> <link rel="stylesheet" href="http://code.jquery.com/mobile/1.1.0/jquery.mobile-1.1.0.min.css" /> <script type="text/javascript" src="http://img.558idc.com/uploadfile/allimg/210615/21230235b-6.jpg"></script> <script type="text/javascript" src="http://img.558idc.com/uploadfile/allimg/210615/2123024950-7.jpg"></script> </head> <body> <div data-role="page" id="third"> <div data-role="header"> <h1>jQuery Mobile</h1> </div> <div data-role="content"> <ul id="listOfItems" data-role="listview" data-inset="true" data-filter="true"> <li><a href="">One</a> </li> <li><a href="">Two</a> </li> <li><a href="">Three</a> </li> </ul> </div> <div data-role="footer"> <h4>www.jboss.org/developer</h4> </div> </div> </body> </html>
common.js
$(document).on('pageinit', "#first", function (event) { console.log("first"); }); $(document).on('pageinit', "#second", function (event) { console.log("second"); }); $(document).on('pageinit', "#third", function (event) { console.log("third"); });
你能查看上面的代码,让我知道为什么每次调用pageinit.
介绍在我们讨论页面事件之前,我们需要讨论jQuery Mobile页面架构. jQuery Mobile应用程序可以通过两种不同的方式创建,即多页面模板或多个HTML页面.
不同的jQuery Mobile页面架构
多页模板
在这种模板中,所有内容都被加载到DOM中.无论用户从一个页面转换到另一个页面多少次都将保持加载到DOM中.虽然这是在页面之间平滑过渡的最佳解决方案,但它可能会给DOM带来负担.这通常不是桌面浏览器的问题,但移动浏览器可能会受到影响,特别是在低端设备上.
多HTML模板
此模板解决方案需要多个HTML页面.它是大型移动应用程序构建的绝佳选择,但有一个问题.与每页访问页面的多页面模板不同,它将加载到DOM中.在较慢的设备上,它可能会导致转换问题,尤其是在目标页面很大的情况下.这可以通过页面预取来解决,其中jQuery Mobile在主页面加载并触发了pagecreate事件后在后台加载目标页面.但是还有另一个大问题,这在jQuery Mobile文档中没有充分描述.在页面转换期间,将从DOM中删除上一页.这样做是为了防止DOM内部的内容累积.使用另一个名为的属性也可以防止这种情况:
data-dom-cache="true"
或者通过初始化全局参数:
$.mobile.page.prototype.options.domCache = true;
页面架构如何影响页面事件
jQuery Mobile有几个页面事件(更多关于它可以找到HERE或HERE).它们在这里涵盖整页加载/转换过程.高级jQuery Mobile用户知道使用pageinit事件而不是jQuery经典文档就绪事件.就像文档就绪一样,pageinit在页面初始化期间只触发一次.
但是有一个问题,pageinit只会在DOM内部的页面初始化期间触发一次.如果页面从DOM中删除(在多HTML模板中)并再次加载,则会再次触发pageinit.
简而言之,每个页面的DOM初始化都会触发新的页面事件初始化.如前所述,这可以通过页面兑现来防止.
页面兑现的影响
这几乎是jQuery Mobile开发人员的禁忌主题,所以让我讲一些事情,没有必要害怕页面兑现.相信我,jQuery Mobile是一个强大的框架,它通常在每个可用平台上都能很好地运行.与jQuery Mobile相关的大量抱怨与其大的DOM大小要求没有直接关系,因此不必担心兑现.
这并不意味着你应该像喝醉酒的水手那样填补DOM.每个应用程序开发都必须提前计划.大多数使用的页面必须永久保留在DOM中.其他所有内容都应该特别使用(需要时加载/删除).