Silverlight程序集引用相关问题解疑
创始人
2024-06-19 01:21:37
0

当我们在使用Silverlight开发工具进行实际操作的时候,并不是一个一帆风顺的事情。在变成过程中同样会出现各种各样的问题。在这里我们就为会为大家解决Silverlight程序集引用的相关问题。#t#

假定我要用Silverlight类库实现一些通用控件,然后在应用程序中引用这个控件库。当然,控件通常也要访问其他一些第三方或开源的开发包,例如Silverlight Toolkit。

于是这个项目的依赖关系如下: Silverlight Application => Silverlight Control => Silverlight Toolkit。

 

 

然后在类库项目中创建一个简单的Silverlight程序集引用控件,比如:
 

 

  1. < UserControl x:Class="SLLib.
    TestControl"
     
  2. xmlns="http://schemas.microsoft.
    com/winfx/2006/xaml/presentation"
       
  3. xmlns:x="http://schemas.microsoft.
    com/winfx/2006/xaml"
       
  4. xmlns:controlsToolkit="clr-namespace
    :System.Windows.Controls;assembly
    =System.Windows.Controls.Toolkit"
       
  5. > 
  6. < Grid x:Name="LayoutRoot"> 
  7. < controlsToolkit:DockPanel> 
  8. < /controlsToolkit:DockPanel> 
  9. < /Grid> 
  10. < /UserControl> 

 

 

最后,在Silverlight程序集引用中添加我们刚刚创建的控件:

 

  1. < UserControl x:Class="TestSL.MainPage" 
  2. xmlns="http://schemas.microsoft.
    com/winfx/2006/xaml/presentation"   
  3. xmlns:x="http://schemas.microsoft.
    com/winfx/2006/xaml" 
  4. xmlns:d="http://schemas.microsoft
    .com/expression/blend/2008"   
  5. xmlns:mc="http://schemas.openxml
    formats.org/markup-compatibility/2006"   
  6. mc:Ignorable="d" 
  7. xmlns:lib="clr-namespace:SLLib;
    assembly=SLLib"> 
  8. < Grid x:Name="LayoutRoot"> 
  9. < lib:TestControl /> 
  10. < /Grid> 
  11. < /UserControl> 

 

 

这么简单的程序(一行代码也没有),不可能出问题吧?可惜事实上不是这样,错误还是出现了。

 

 

那么Silverlight程序集引用出现错误的原因在哪呢?我们打开.xap 文件看看,就会发现问题:Toolkit程序集竟然没有被包含进来!这样控件运行的时候是无法找到DockPanel类的,程序自然就出错了。

我们可以从其他方面来验证这个错误。删掉原来的控件(其实不删也可以) ,从代码创建一个控件:

  1. public class TestControl2 :
     ContentControl  
  2. {  
  3. public TestControl2()  
  4. {  
  5. this.Content = new DockPanel();  
  6. }  

然后把程序中的TestControl换成TestControl2,再试试看怎么样?运行正常!.xap文件现在也包含Toolkit了。

 

 

另一方面,如果我们在应用程序的引用中手工加上System.Windows.Controls.Toolkit,那么程序也可以运行正常。

 

这些迹象表明,Silverlight编译器实在有点自作聪明。即使我们在类库引用中明确指定了要引用的程序集,编译器也会忽略这些指示,只查找代码中使用到的那些。对于你在.xaml中引用的程序集,编译器根本不予理会。让情况更加恶化的是,如果运行时找不到类,那么Silverlight运行时只会抛出臭名卓著的AG_E_PARSER_BAD_TYPE,这个毫无内容的错误信息对查找问题没有什么帮助。奇怪的是对于Application类型的项目,Silverlight编译器的做法则完全不同——只要在项目引用中加入了任何程序集,无论实际上是否被用到,都会编译到最终的.xap文件中。这种不一致的行为是你应当小心的。

Silverlight程序集引用问题最简单的work around就是:只要在类库中引用了哪些程序集,在应用程序中也保证引用同样的程序集,就可以避免出现错误。显然这不是一个很理想的办法,不仅因为它迫使程序员重复做一些没有实际意义的工作,也使得类库的使用者不得不去关心类库的内部机制,从而让类库的存在意义大打折扣。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...