开源一个 Sliverlight 导航框架

开源项目中的一个 Silverlight 导航框架, 源代码已经发布到 GitHub, 地址为 https://github.com/beginor/AssemblyNavigation 。

特点

按需加载 Silverlight 组件
与 SL 内置实现了真正意义的按需加载, 主程序可以非常小, 最小不超过 200 KB, 只有当点击链接之后, 才会去服务端下载 对应的组件, 每个组件文件只会下载一次。 如果要下载的组件引用了其它第三方的组件, 也会自动下载第三方组件, 下载第这些 时会自动过滤掉重复的组件。
几乎零配置
使用这个导航框架几乎不需要在客户端或服务端做任何配置, 整个加载过程是自动完成的, 你需要写的只是导航的菜单项。

使用方法

主程序

1. 添加对 AssemblyNavigation、 System.Windows.Controls.Navigation 的引用至项目;

2. 在主页面的 xaml 代码添加下面的 xmlns 引用:

1
2
xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk" 
xmlns:asmNav="clr-namespace:Beginor.AssemblyNavigation;assembly=Beginor.AssemblyNavigation"

3. 添加 Frame 控件并设置 ContentLoader, 代码如下:

1
2
3
4
5
< sdk:Frame  Name="MainFrame" Grid.Row="1" Source="MainApp.WelcomePage,MainApp">
    < sdk:Frame.ContentLoader >
       < asmNav:AssemblyNavigationContentLoader  />
    </ sdk:Frame.ContentLoader >
</ sdk:Frame >
模块

每个模块需要添加对 System.Windows.Controls.Navigation 的引用, 至少要有一个页面(否则就不是模块了), 这个 页面需要继承自 System.Windows.Controls.Page 类。

导航链接地址格式

导航地址的链接地址格式为要显示的模块的完整的类型名称, 例如:

1
2
3
4
5
6
< StackPanel  Orientation="Horizontal">
< HyperlinkButton  Content="Welcome Page" NavigateUri="MainApp.WelcomePage,MainApp"/>
< HyperlinkButton  Content="Chart Page" NavigateUri="ChartModule.ChartPage,ChartModule"/>
< HyperlinkButton  Content="Map Page" NavigateUri="MapModule.MapPage,MapModule"/>
< HyperlinkButton  Content="Grid Page" NavigateUri="GridModule.GridPage,GridModule"/>
</ StackPanel >

如果还不够清楚, 可以从 GitHub 网站项目下载这个项目, 有一个完整的测试程序。

注意问题

  • 如果模块引用的第三方组件只在 xaml 中使用, 则必须添加 x:Name 属性, 否则可能会出现找不到这个第三方组件的问题;
  • 如果模块的 xaml 中引用了 clrnamespace , 则必须指定 assembly 值, 否则也可能会出现问题。

张志敏所有文章遵循创作共用版权协议,要求署名、非商业 、保持一致。在满足创作共用版权协议的基础上可以转载,但请以超链接形式注明出处。

本博客已经迁移到 GitHub , 围观地址: http://beginor.github.io/


本文转自张志敏博客园博客,原文链接:http://www.cnblogs.com/beginor/archive/2012/06/08/2542110.html,如需转载请自行联系原作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值