艾伟_转载:Silverlight陷阱:注意程序集引用问题

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

  于是这个项目的依赖关系如下: Silverlight Application => Silverlight Control => Silverlight Toolkit。在Visual Studio中创建好项目之间的引用关系:

  然后在类库项目中创建一个简单的控件,比如:

UserControl x:Class="SLLib.TestControl"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
    xmlns:controlsToolkit="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Toolkit" 
    >
    Grid x:Name="LayoutRoot">
        controlsToolkit:DockPanel>
        controlsToolkit:DockPanel>
    Grid>
UserControl>

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

UserControl x:Class="TestSL.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
    mc:Ignorable="d"
    xmlns:lib="clr-namespace:SLLib;assembly=SLLib">
    
    Grid x:Name="LayoutRoot">
        lib:TestControl />
    Grid>
    
UserControl>

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

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

 

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

public class TestControl2 : ContentControl
{
    public TestControl2()
    {
        this.Content = new DockPanel();
    }
}

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

 

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

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

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

时间: 2024-09-29 17:29:37

艾伟_转载:Silverlight陷阱:注意程序集引用问题的相关文章

艾伟_转载:WPF/Silverlight陷阱:XAML自定义控件的嵌套内容无法通过名称访问

为了说明这个问题,假定我们需要实现一个具有特殊功能的按钮控件.编写Xaml文件如下: <Button x:Class="TestWpf.XamlButton"    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">Button> 对

艾伟_转载:VS 2010 和 .NET 4.0 系列之《添加引用对话框的改进》篇

本系列文章导航 VS 2010 和 .NET 4.0 系列之<ASP.NET 4 中的SEO改进 >篇 VS 2010 和 .NET 4.0 系列之<干净的Web.Config文件 >篇 VS 2010 和 .NET 4.0 系列之<起始项目模板>篇 VS 2010 和 .NET 4.0 系列之<多定向支持>篇 VS 2010 和 .NET 4.0 系列之<多显示器支持>篇 VS 2010 和 .NET 4.0 系列之<代码优化的Web开发

艾伟_转载:单件模式的陷阱

看过很多单件模式的文章,书上有,网上更多一些.一般来说,只有如何实现单件模式,而没有介绍具体情况单件模式的使用,也没有介绍过单件模式会出现问题.单件模式似乎不会产生逻辑上的问题.但是,这仅仅是似乎. 在描述我遇到的问题之前,先讲讲我对其原理的理解. 首先单件模式是自我创建的一个对象,并且在运行期始终保持只有唯一的对象.抛开什么东西能够自我创建不说,保持唯一对象要怎么理解呢?先看看一个普通的类: package singleton; public class SimpleClass { } 对其进

艾伟_转载:关于.NET中的循环引用

在现在开发模式日益增多,框架泛滥的时代里,人们越来越多的依赖于固有的框架模式的开发而忽略了对项目底层架构的理解.所以在部署项目结构的时候,会遇到"循环引用"这个问题,今天我就遇到了. 其实说起来并不复杂,就是我有5个项目A,B,C,D,E,然后我在项目A中引用了B的类,然后又在B中引用了C的类,最后又在C中引用了A中的类,这就构成了循环引用. 那么碰到这样的问题,怎么解决呢? 解决方案一: 我们考虑创建新的一个项目Z,然后分别添加对A,B,C的引用,这样A,B,C只要引用Z就行了. 解

艾伟_转载:基于.NET平台的Windows编程实战(五)—— 问卷管理功能的实现

本系列文章导航 基于.NET平台的Windows编程实战(一)--前言 基于.NET平台的Windows编程实战(二)-- 需求分析与数据库设计 基于.NET平台的Windows编程实战(四)-- 数据库操作类的编写 基于.NET平台的Windows编程实战(五)-- 问卷管理功能的实现 基于.NET平台的Windows编程实战(六)-- 题目管理功能的实现 首先,为了使我们的界面更加便于操作及布局,我们引入第三开源控件DockPanel[当然也可以不引入控件而直接进行开发],你可以从这里:Do

艾伟_转载:WCF安全之EndPointIdentity

最近在做一个项目,应用了WCF进行分布式开发,中间还涉及到消息路由器等,好在有WCF提供了强大的基础支持,当然,本身也作了不少的扩展,实际,我 最关心的是WCF的安全问题,网上不少朋友介绍的WCF的安全也是少得可怜,微软发布的WCF Security GUID好像讲得也只是入门级别的教程,离真正应用到项目中还是有很大的距离,这也让我萌发了分享的想法,今天先放出来占个位置吧,有反对的朋友砖头轻 点,呵~,可以告诉你,WCF的安全里,有很多的小秘密,当然还是要告诉你,并且有此小秘密是要自己去体验后才

艾伟_转载:老赵谈IL(3):IL可以看到的东西,其实大都也可以用C#来发现

在上一篇文章中,我们通过一些示例谈论了IL与CLR中的一些特性.IL与C#等高级语言的作用类似,主要用于表示程序的逻辑.由于它同样了解太多CLR中的高级特性,因此它在大部分情况下依旧无法展现出比那些高级语言更多的CLR细节.因此,如果您想要通过学习IL来了解CLR,那么这个过程很可能会"事倍功半".因此,从这个角度来说,老赵并不倾向于学习IL.不过严格说来,即使IL无法看出CLR的细节,也不足以说明"IL无用"--这里说"无用"自然有些夸张.但是

艾伟_转载:VS 2010 和 .NET 4.0 系列之《干净的Web.Config文件 》篇

本系列文章导航 VS 2010 和 .NET 4.0 系列之<ASP.NET 4 中的SEO改进 >篇 VS 2010 和 .NET 4.0 系列之<干净的Web.Config文件 >篇 VS 2010 和 .NET 4.0 系列之<起始项目模板>篇 VS 2010 和 .NET 4.0 系列之<多定向支持>篇 VS 2010 和 .NET 4.0 系列之<多显示器支持>篇 VS 2010 和 .NET 4.0 系列之<代码优化的Web开发

艾伟_转载:WCF基本异常处理模式[中篇]

通过WCF基本的异常处理模式[上篇], 我们知道了:在默认的情况下,服务端在执行某个服务操作时抛出的异常(在这里指非FaultException异常),其相关的错误信息仅仅限于服务端可见,并不会被WCF传递到客户端:如果将开启了IncludeExceptionDetailInFaults的ServiceDebug服务行为通过声明(通过在服务类型上应用ServiceBehaviorAttrite特性)或者配置的方式应用到相应的服务上,异常相关的所有细节信息将会原封不动地向客户端传送. 这两种方式体