自制Silverlight页面跳转缓存

本文介绍了一种使用Dictionary存储页面对象以实现页面缓存的方法,通过自定义跳转逻辑避免了因页面刷新导致的数据丢失问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果在一个页面我们正在处理一些事情,可是一些信息的参考需要跳转到另一个页面,可当我们返回回来发现我们页面之前的数据被刷新了,是不是有杀人的冲动呢,不急,下面我们就自己做一个页面的缓存.

  其实,这个页面缓存的原理很简单,使用一个Dictionary存放一些我们我要要进行缓存的页面的名字和页面的对象,ok,废话不多说,开始实现.

  1.定义一个枚举,表示我们要缓存的页面(其实我们可以用string类型来代替,不过枚举的话可以保证我们的访问不会出错,毕竟已经写好了,扩展起来也很方便,也是全局的)

public enum Pages
    {
        NavigationRootVisual, NavigationCache
    }

  这个枚举很简单的,就是定义了一些我们需要缓存的页面的名字,当然可以自行添加很多的.

  2.定义一个Dictionary类型的集合,存放已经被缓存的页面

  private static Dictionary<Pages, UserControl> pageCache = new Dictionary<Pages, UserControl>();

  3.开始了重头戏,自定义跳转方法,由于需要进行页面的自定义跳转,所以是先修改了 StartUp中RootVIsual的设置,其实道理很简单,只不过放了一个Grid来实现UserControl的替换.

        private Grid rootGrid = new Grid();//定义一个Grid实现页面的跳转
  private void Application_Startup(object sender, StartupEventArgs e)
        {
            UserControl startPage = new NavigationRootVisual();
           //将当前页面的根设置为Grid
            this.RootVisual = rootGrid;
            //通过给Grid添加项来实现页面的跳转
            rootGrid.Children.Add(startPage);
            // 保存起始页的缓存(可选)
            pageCache[Pages.NavigationRootVisual] = startPage;
        }

  自定义跳转方法

public static void Navigate(Pages newPage)
        {
             //得到当前的App,之所以要进行转换,MSDN的解释是Application.CUrrent只是一个基类的引用,
            //所以要转换
            App currentApp = (App)Application.Current;
            //得到当前根的页面UserControl,是为了得到Namespace(当前的跳转仅限于同一个Namespace,大家可以自行扩展)
            UserControl root = currentApp.rootGrid.Children[0] as UserControl;
            //如果当前缓存集合中不存在,则进行添加
            if (!pageCache.ContainsKey(newPage))
            {
                Type type = root.GetType();
                Assembly assembly = type.Assembly;
                //通过反射创建要跳转的UserControl
                pageCache[newPage] = (UserControl)assembly.CreateInstance(
                type.Namespace + "." + newPage.ToString());
            }

            currentApp.rootGrid.Children.Clear();
            //将新的页面放到Grid,即可显示
            currentApp.rootGrid.Children.Add(pageCache[newPage]);
        }

  ok,到此工作已经结束,看看效果.

  一共有两个页面,Page1和Page2

  我们给TextBox填写信息,用于实验是否缓存了

  在这里还有一个关键代码,按钮的事件,按钮进行了页面的跳转,看看我们怎么跳转的

  private void btnNavigation_Click(object sender, RoutedEventArgs e)
        {
            App.Navigate(Pages.NavigationCache);
        }

  不错我们使用了App中自定义的跳转方法,参数也就是我们要跳转页面对应的枚举值.

  Page2只是一个按钮,用于返回回去,按钮的代码和Page1的类似,只是枚举值不一样,在此不再给出,当我们点击按钮回去之后发现,我们的page1中的TextBox还有值,哈哈,大功告成.

1. 用户与权限管理模块 角色管理: 学生:查看实验室信息、预约设备、提交耗材申请、参与安全考核 教师:管理课题组预约、审批学生耗材申请、查看本课题组使用记录 管理员:设备全生命周期管理、审核预约、耗材采购与分发、安全检查 用户操作: 登录认证:统一身份认证(对接学号 / 工号系统,模拟实现),支持密码重置 信息管理:学生 / 教师维护个人信息(联系方式、所属院系),管理员管理所有用户 权限控制:同角色仅可见对应功能(如学生可删除设备信息) 2. 实验室与设备管理模块 实验室信息管理: 基础信息:实验室编号、名称、位置、容纳人数、开放时间、负责人 功能分类:按学科(计算机实验室 / 电子实验室 / 化学实验室)标记,关联可开展实验类型 状态展示:实时显示当前使用人数、设备运行状态(正常 / 故障) 设备管理: 设备档案:名称、型号、规格、购置日期、单价、生产厂家、存放位置、责任人 全生命周期管理: 入库登记:管理员录入新设备信息,生成唯一资产编号 维护记录:记录维修、校准、保养信息(时间、内容、执行人) 报废处理:登记报废原因、时间,更新设备状态为 "已报废" 设备查询:支持按名称、型号、状态多条件检索,显示设备当前可用情况 3. 预约与使用模块 预约管理: 预约规则:学生可预约未来 7 天内的设备 / 实验室,单次最长 4 小时(可设置) 预约流程:选择实验室→选择设备→选择时间段→提交申请(需填写实验目的) 审核机制:普通实验自动通过,高危实验(如化学实验)需教师审核 使用记录: 签到 / 签退:到达实验室后扫码签到,离开时签退,系统自动记录实际使用时长 使用登记:填写实验内容、设备运行情况(正常 / 异常),异常情况需详细描述 违规管理:迟到 15 分钟自动取消预约,多次违规限制预约权限 4. 耗材与安全管理模块 耗材管理: 耗材档案:名称、规格、数量、存放位置、
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值