• Silverlight关于窗体的跳转及传递参数的解决方案


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

    案例:现在有一个登陆窗口,如果用户登陆成功以后成功页面,并把用户名传到主页,没有成功就到原始页面;

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

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

    效果如图:

     传递后转向的页面

     

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

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

    Grid rootGrid = new Grid();

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

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

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

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

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

     

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

    代码
    1 public void RedirectTo(UserControl userControl)
    2 {
    3 App app = (App)Application.Current;①
    4 app.rootGrid.Children.Clear();②
    5 app.rootGrid.Children.Add(userControl);③
    6 }

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

      ①:它的意思就是得到当应用程序的对象;

      ②:刚才我们不是对Grid里面添加Login页面进去了,现在为了添加成功页面进去,我们必须把Grid控件中的Login清除掉;

      ③这上操作是建立在②的基础之上的,没有它的Clear就不能添加;所以这一步就是在添加新页面;

     

     4.我们怎么来调用这个方法呢?不难看出这个方面的参数类型是UserControl,是一个控件;在调用它时我们传一个就是一个页面;

    代码
    1 private void btnLogin_Click(object sender, RoutedEventArgs e)
    2 {
    3 App app = (App)Application.Current;
    4 //app.RedirectTo(new MainPage());
    5   app.RedirectTo(new MainPage("测试参数"));
    6 }

    在要转向的页面中加入一个有参的构造函数,就可以在xaml页面中传参了。

    1 public MainPage(string userName)
    2 {
    3 InitializeComponent();
    4 this.Name = userName;
    5 btnIndex.Content = this.Name;
    6 }

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

  • 相关阅读:
    How to run Java main class and pass application arguments in Maven?
    【转】三年后再反思我的" Java Web项目管理得失谈"
    Object.keys()
    angular $resource 的 get请求 和 post请求
    vue 自定义 移动端筛选条件
    获取当前时间 YYYY-MM-DD
    vue-router 二级路由
    blob 对象 实现分片上传 及 显示进度条
    js性能优化之函数节流(分流函数)
    vue + vue-lazyload 实现图片懒加载
  • 原文地址:https://www.cnblogs.com/homezzm/p/1627329.html
Copyright © 2020-2023  润新知