• jQuery_mobile页面跳转事件学习


     



    <html>
        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
            <link rel="stylesheet" href="http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.css">
            <script src="http://code.jquery.com/jquery-1.8.3.min.js">
            </script>
            <script src="http://code.jquery.com/mobile/1.3.2/jquery.mobile-1.3.2.min.js">
            </script>
            <script type="text/javascript">
    $(document).ready(function(){
    console && console.log($(this).attr('id') + "-document  ready执行");
                });
                
                $(document).on('pagecreate''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + " - pagecreate!!");
                });
                
                $(document).on('pagebeforecreate''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + " - pagebeforecreate!!");
                });
                
                $(document).on('pagebeforeshow ''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + "-pagebeforeshow执行");
                });
                
                $(document).on('pageshow''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + "-pageshow执行");
                });
                
                $(document).on('pageinit''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + "-pageinit执行");
                });
                
                $(document).on("pagebeforechange"function(e, data){
                    console && console.log($(this).attr('id') + "-pagebeforechange!!"); 
                });
                
                $(document).on('pagechange'function(e, data){
                    console && console.log($(this).attr('id') + "-pagechange!!");
                });
                
                
                $(document).on('pagebeforehide''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + " - pagebeforehide!!");
                });
                
                $(document).on('pageremove''[data-role="page"]'function(){
                    console && console.log($(this).attr('id') + " - pageremove!!");
    });
    $(document).on('pagehide''[data-role="page"]'function(){
    console && console.log($(this).attr('id') + " - pagehide!!");
    });
    $(document).on('pagebeforeload''[data-role="page"]',function(){
    console && console.log($(this).attr('id')+"-pagebeforeload!!");
    });
    $(document).on('pageload''[data-role="page"]',function(){
    console && console.log($(this).attr('id')+"-pageload!!");
    });
    </script>
    </head>
    <body>
    <!--页面一-->
    <div data-role="page" id="pageone" data-theme="e">
    <div data-role="header">
    <h1>header</h1>
    </div>
    <div data-role="content">
    <p>
    content
    </p>
    <a href="#pagetwo" data-role="button">pageone-button</a>
    </div>
    <div data-role="footer">
    <h1>footer</h1>
    </div>
    </div>
    <!--//页面二-->
    <div data-role="page" id="pagetwo" data-theme="d">
    <div data-role="header">
    <h1>header</h1>
    </div>
    <div data-role="content">
    <p>
    content
    </p>
    <a href="#pagethree" data-role="button" data-rel="dialog">pagetwo-button</a>
    </div>
    <div data-role="footer">
    <h1>footer</h1>
    </div>
    </div>
    <!--//页面三-->
    <div data-role="page" id="pagethree" data-overlay-theme="e">
    <div data-role="header" data-theme="b">
    <h1>header</h1>
    </div>
    <div data-role="content" data-theme="a">
    <p>
    data-overlay-theme 属性规定对话框出现在其上的页面的背景色。
    </p>
    <a href="#pageone">转到pageone</a>
    </div>
    <div data-role="footer" data-theme="c">
    <h1>footer</h1>
    </div>
    </body>
    </html>

    “页面一”初次加载的顺序:

    控制台打印:
    undefined-pagebeforechange!!
    pageone - pagebeforecreate!!
    pageone - pagecreate!!
    pageone-pageinit执行
    pageone-pagebeforeshow执行
    pageone-pageshow执行
    undefined-pagechange!!
    undefined-document  ready执行

    从页面一调到页二的执行顺序:

    控制台打印结果:
    undefined-pagebeforechange!!
    pagetwo - pagebeforecreate!!
    pagetwo - pagecreate!!
    pagetwo-pageinit执行
    undefined-pagebeforechange!!
    pageone - pagebeforehide!!
    pagetwo-pagebeforeshow执行
    pageone - pagehide!!
    pagetwo-pageshow执行
    undefined-pagechange!!

    从页面二调到页面三(是一个dialog)的执行顺序:

    控制台打印结果:
    undefined-pagebeforechange!!
    undefined-pagebeforechange!!
    pagetwo - pagebeforehide!!
    pagetwo - pagehide!!
    undefined-pagechange!!

    从页面三回到页面一的执行顺序:

    控制台打印结果:
    undefined-pagebeforechange!!
    undefined-pagebeforechange!!
    pageone-pagebeforeshow执行
    pageone-pageshow执行
    undefined-pagechange!!

    再次从页面一到页面二的执行顺序:

    控制台信息:
    undefined-pagebeforechange!!
    undefined-pagebeforechange!!
    pageone - pagebeforehide!!
    pagetwo-pagebeforeshow执行
    pageone - pagehide!!
    pagetwo-pageshow执行
    undefined-pagechange!!

    再次从页面二到页面三的顺序:

    控制台信息:
    undefined-pagebeforechange!!
    undefined-pagebeforechange!!
    46pagetwo - pagebeforehide!!
    54pagetwo - pagehide!!
    41undefined-pagechange!!

    再次从页面三回到页面一的顺序:

    控制台信息:
    undefined-pagebeforechange!!
    undefined-pagebeforechange!!
    pageone-pagebeforeshow执行
    pageone-pageshow执行
    undefined-pagechange!!

    总结:

    每个页面第一次加载的时候会调用:pagebeforecreate   ,    pagecreate  ,    pageinit方法对其完成创建和初始化;

    在三个方法只调用一次,下次跳转显示的时候因为页面已经创建了,所以只会调用pagebeforeshow,pageshow,完成显示。

     
  • 相关阅读:
    h5唤起app
    app唤起的完美解决方案,及阻止浏览器的默认弹窗行为
    cdn
    函数声明和函数表达式的区别
    基础系列(7)—— 结构
    基础系列(4)—— C#装箱和拆箱
    重温软件工程——对软件工程的初步了解
    基础系列(9)—— 抽象方法和接口
    自学系列--git的基础简介
    设计模式之简单工厂模式
  • 原文地址:https://www.cnblogs.com/zxz-zxz/p/6220530.html
Copyright © 2020-2023  润新知