jQuery Mobile:文档就绪与页面事件
了解差异
在 jQuery Mobile 中,有两种主要方法可以在页面执行时执行代码已加载:
-
文档就绪($(document).ready()):当 DOM 加载并且所有元素可用时触发此事件。但是,在 jQuery Mobile 中,此事件有时可能在使用 Ajax 加载和操作页面之前执行得太早。
-
页面事件 ($('.selector').on('pageinit/pagebeforeshow' )):这些事件是专门为 jQuery Mobile 设计的,在页面初始化时或显示之前触发。它们确保仅在加载特定页面时执行代码。
为什么页面事件更好:
- 它们确保代码被执行仅当目标页面加载且可见时。
- 它们提供了一种更可预测且一致的方式来处理页面
页面事件转换顺序
在 jQuery Mobile 中从一个页面转换到另一个页面时,将按以下顺序触发一系列页面事件:
- 页面 B:创建前的页面
- 页面 B:创建页面
- 页面B: pageinit
- 页面 A: pagebeforehide
- 页面 A: pageremove
- 页面 A: pagehide
- 页面 B: pagebeforeshow
- 页面B:页面显示
数据操作和参数传递
将数据从一个页面发送到另一页面:
- 使用带有 data 和 dataUrl 选项的 $.mobile.changePage() 将参数传递给新页面。
- 在目标页面中,使用 $(document).data() 或$(document).data("url") 获取查询字符串。
访问上一页的数据:
- 存储全局变量中的数据或使用 sessionStorage 对象。
- 从新的共享位置检索数据
防止多个事件绑定
要防止在页面之间导航时在同一元素上绑定多个事件:
- 使用页面事件而不是文档准备好了。
- 使用事件过滤器(例如:Event(!click))来确保仅绑定事件一次。
- 在事件处理程序中使用 e.handled = true 来防止重新触发。
以上是jQuery Mobile:文档就绪或页面事件:哪个更适合处理页面加载?的详细内容。更多信息请关注PHP中文网其他相关文章!