(牛人莫入)Silverlight 3.0 关于窗体的跳转解决方案

阅读条件:本篇文章适合SL的初学者阅读,如果你不是初者请你放弃阅读;不文不将对SL的高级开发者提供认何帮助;

我们如何能把SL利用像熟练呢?就像写Web应用程序一样呢?

其实这个问题也很简单,只要在平时多关心SL,了解SL就可以了,如果你对它很陌生,那么它也对你一样的陌生,这两者是成正比的;

今天我就给大家讲一下在Silverlight 3.0是关于Redirect页面的跳转,与ASP.NET页面的跳转一样;

 

案例:现在有一个登陆窗口,如果用户登陆成功以后成功页面,没有成功就到原始页面;如果没有登陆提示用户去登陆;这样一个需求在ASP.NET 很好解决,

但是在Siverlight API 文档 中目前还没有提供写好的方法来解决这个问题;这个问题其实也不算很难,通过看Silverlight API 也可以找到解决方案;接下来

我就为大家提供两种方案来解决这个问题吧;

 

解决方案一:

运行效果如下:

image

我们可以从App.cs文件中来解决;我们可以在App中定义一个全局的变量;

1.我们先在App中定义一个Grid控件;代码如下所示:

Grid rootGrid = new Grid();

2.当整个应用程序启动运行时,让它第一个页面Login页面;在Application Startup事件中来处理解决,先看一下代码:

private void Application_Startup(object sender, StartupEventArgs e)
       {
           this.RootVisual = rootGrid;①
           this.rootGrid.Children.Add(new Login());②
       }

这句代码是什么意思呢?分析如下:

①:当整个应用程序启动时,程序的主界面加载就是Grid;

②Grid控件加载完成了,那么它的创建也完成,接下我们就可以为它添加一个子页面;

3.登陆时的主页面问题就完全解决了,但是登陆成功后我们又怎么来转向成功后的页面呢;我们还是在App.cs里面写一个方法来解决,

先看代码;

      /// <summary>
      /// 页面跳转
       /// </summary>
      /// <param name="usercontrol"></param>
      public void RedirectTo(UserControl usercontrol)
      {
          App app = (App)Application.Current;①
          app.rootGrid.Children.Clear();②
          app.rootGrid.Children.Add(usercontrol);③
      }
这三句代码是什么意思呢?分析结果如下:
①:它的意思就是得到当应用程序的对象;
②:刚才我们不是对Grid里面添加Login页面进去了,现在为了添加成功页面进去,我们必须把Grid控件中的Login清除掉;
③这上操作是建立在②的基础之上的,没有它的Clear就不能添加;所以这一步就是在添加新页面;
4.我们怎么来调用3这个方法呢?不难看出3这个方面的参数类型是UserControl,是一个控件;在调用它时我们传一个就是一个页面;
            App app = (App)Application.Current;
            app.curUserName = txtUserName.Text.Trim();
            app.RedirectTo(new MainPage());

关于App文件的介绍我在这里就不介绍了,可以在他里面可以定义全局变得,比如:可以定义一个变量来判断是否是登陆用户,这些都可以来做到的;

每一个解决方案就介绍到这里;

解决方案二:

在方案二中与方案一有很多的相似的地方,我就简单的介绍一下;

1.当应用程序运行起来时,向加载成功的页面,在加载成功页面的同时我们在他的Loaded事件中执行一个模态窗体(Login);代码如下:

Login s = new Login();
s.Show();
如果登陆成功就回到主页面了;
2.如果在这里我们不用模态窗体用普通的一个页面,如何解决呢?普通页面这里也方案一很相似;先得以主页面中声明一个UserControl这个对象;
UserControl _userControl;

3.在主页面的Loaded事件中写如下代码:

            Login login;
            _userControl = new Login();
            login = _userControl as Login;
            this.ContentHolder.Children.Add(login);
在这里与解决方案一基本上是一样的;只是换了一个角度去考虑一;
补充解决方案:
关于页面的跳转也有很多的解决方案,关键是如何去发现问题?还得靠平时的积累;
在有的资料文档中还提供一种用委托来解决,这一种也是一个不错的解决方案;在这里我就不详细说了;
 
 
结束语:本文是以基础为目地,给初学者一点小的帮助是作者最大的心愿;
 
 

作者:caodaiming(一起学习,共同进步)
出处:www.cnblogs.com/caodaiming
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

 
 
posted @ 2009-09-26 07:32  阳光追梦  阅读(2607)  评论(6编辑  收藏  举报
/*快速评论*/ #div_digg { position: fixed; bottom: 10px; right: 15px; border: 2px solid #ECD7B1; padding: 10px; width: 140px; background-color: #fff; border-radius: 5px 5px 5px 5px !important; box-shadow: 0 0 0 1px #5F5A4B, 1px 1px 6px 1px rgba(10, 10, 0, 0.5); } /** 不知道为什么页面加载完成时还读不到div_digg。可能也是动态生成的。 所以这里只能用定时器 不断的读取,当读取到了再给它动态添加快捷按钮 **/ //自定义 定时器[当元素加载完成是执行回调函数] function customTimer(inpId,fn) { if ($(inpId).length) { fn(); } else { var intervalId = setInterval(function () { if ($(inpId).length) { //如果存在了 clearInterval(intervalId); // 则关闭定时器 customTimer(inpId,fn); //执行自身 } }, 100); } } //页面加载完成是执行 $(function () { customTimer("#div_digg", function () { var div_html = "
\ 关注\  | \ 顶部\  | \ 评论\
"; $("#div_digg").append(div_html); //tbCommentBody }); });