• windows phone mango 页面跳转事件顺序


    最近发现自己做的东西出现了bug:经过几次页面反复跳转后,退出时发现需要一次又一次的返回BackStack里面的页面,然后才能真正退出应用。

    之前看到大家写的关于应用程序历史记录的文章,感觉可以从此下手。即:

    1. 每次回到首页的时候都清空BackStack,使得在首页点击后退键时就能直接退出应用程序;

    2. 其他的二级页面不用管它,点击后退按钮时会自动返回上一页;

    3. 二级页面之间要尽量避免互相跳转的问题。

    而以上三点适用于页面较少,页面逻辑较为简单的操作,如果你的程序页面较多,页面逻辑复杂,需要二级、三级页面互相跳转,那就需要总体把握,另选方案。你也可以在ApplicationBar上面有个“返回首页”的操作,然后再在跳转至首页时清空BackStack。

    既然需要对BackStack进行操作,那我必须知道页面是什么时候将页面记录加入到BackStack里的。我在页面的Loaded、OnNavigatingFrom、OnNavigatedFrom、OnNavigatedTo事件中加入对NavigationService.BackStack.Count()的输出,发现,每次页面的跳转时间触发顺序为:

    (假设从PageA页面转向PageB页面)                    

    (PageA)OnNavigatingFrom     ====== (此处会将PageA的页面加入到BackStack中)======》    (PageA)OnNavigatedFrom             ==================》    

    (PageB)OnNavigatedTo          ===================================》           (PageB)Loaded

    顺便提一句,应用程序在正常跳转到其他页面时(不是用back键),页面会触发构造函数,而当从backStack里恢复页面(用Back键)或者从休眠状态进入页面时都不会触发构造函数。

     //2011/11/25修改   如果是墓碑机制恢复的话,相当于重新创建页面,会触发页面的构造函数(多谢各位的关注和 jeekun 的提醒)

    接下来我就在MainPage.xaml.cs的OnNavigatedTo事件中加入代码:

                int count  = NavigationService.BackStack.Count();
                if (count > 0)
                {
                    for (int i = 0; i < count;i++ )
                    {
                        NavigationService.RemoveBackEntry();
                    }
                }
    

    这样一来,用户再次通过NavigationService.Navigate或者Url进入首页后,再次点击Back键后,应用程序正常退出。

    大功告成!

    //11.24  14:50 修改:

    我在网上看到了以下代码:

    if ( NavigationService.CanGoBack )

    {

    NavigationService.GoBack();

    }

    突然想起来,竟然忘记解释这个了,现在补上。

    GoBack特点:只能回退一步,如果目标页面有数据要更新,需要把更新代码放在Loaded事件中或者OnNavigatedTo事件中,以便每次进来后都会更新。

    当然,如果结合

    NavigationService.RemoveBackEntry();

    那么还可以达到不错的目的

  • 相关阅读:
    关于vue中如何实现排到他思想
    js 文件下载
    js文件上传
    webpack学习笔记
    this总结
    React中props与state
    js事件总结
    js深拷贝与浅拷贝
    JS设计模式之观察者模式
    ES5与ES6的继承
  • 原文地址:https://www.cnblogs.com/lihaiyin/p/2261363.html
Copyright © 2020-2023  润新知