使用MEF为同一导入提供不同的值

问题描述

| 这个问题与MEF的用法有关。 我想在这两种情况下为同一导入提供不同的值
[Export(\"A1\",typeof(IA))]
[Export(\"A2\",typeof(IA))]
class A : IA
{
  [Import(\"B\")]
  public IB B;
}

[PartCreationPolicy(CreationPolicy.NonShared)]
[Export(typeof(IA))]
class A : IA
{
  [Import]
  public IB B;
}
在上述两种情况下,我都想用不同的值来满足
IB
的导入,这是我在第一类导出中执行的操作
var a1 = Container.GetExportedValue<IA>(\"A1\");
var a2 = Container.GetExportedValue<IA>(\"A1\");
或者在第二次出口中
var a1 = Container.GetExportedValue<IA>();
var a2 = Container.GetExportedValue<IA>();
我希望A
a1
a2
的两个实例具有不同的of1ѭ值。我不想使用
ImportMany
,因为那样的话我必须决定选择哪一个,而我又想将逻辑放在class8ѭ类之外。 与这些导出有关的两种情况是,我希望有一个通用的通用视图,以与实现某些接口的不同类型的视图模型一起使用,以及提供要使用不同配置参数配置的某些服务的类的不同实例。     

解决方法

也许您正在寻找这样的东西?
public class AExporter
{
    [Export(\"A1\",typeof(IA)]
    public IA A1
    {
        get
        {
             return new A(this.B1);
        }
    }

    [Export(\"A2\",typeof(IA)]
    public IA A2
    {
        get
        {
            return new A(this.B2);
        }
    }

    [Import(\"B1\",typeof(IB))]
    public IB B1 { private get; set; }

    [Import(\"B2\",typeof(IB))]
    public IB B2 { private get; set; }

}
但是,MEF并非真正针对这种对合成的细粒度控制而设计的。您可以尝试使用Autofac之类的替代方法,该替代方法与MEF集成良好。     ,我不完全了解您要执行的操作,但是我认为您可以通过在IB导入中指定非共享的创建策略来执行此操作。
[Import(RequiredCreationPolicy=CreationPolicy.NonShared)]
public IB B;