基类中的Autofac属性注入

par*_*ite 5 c# dependency-injection autofac

我正在开发Windows Phone 8.1应用程序,我有一个带有公共属性的基类.

public class ViewModelBase
{
   public ISomeClass MyProp {get;set;}
}
Run Code Online (Sandbox Code Playgroud)

我的派生类看起来像这样

public class MainViewModel : ViewModelBase
{
    private readonly INavigation _navigation;
    public MainViewModel(INavigation navigation)
    {
        _navigation = navigation;
    }
}
Run Code Online (Sandbox Code Playgroud)

在我的App.cs中我有

 var builder = new ContainerBuilder();
 builder.RegisterType<Navigation>().As<INavigation>();
 builder.RegisterType<SomeClass>().As<ISomeClass>();
 builder.RegisterSource(new AnyConcreteTypeNotAlreadyRegisteredSource());
Run Code Online (Sandbox Code Playgroud)

创建MainViewModel时,我的INavigation已解析,但MyProp为null.我试过了

builder.Register(c => new ViewModelBase { MyProp = c.Resolve<ISomeClass>() });

builder.Register(c => new ViewModelBase()).OnActivated(e => e.Instance.MyProp = e.Context.Resolve<ISomeClass>());

builder.RegisterType<ViewModelBase>().PropertiesAutowired();
Run Code Online (Sandbox Code Playgroud)

但它都不起作用!

解决方案发布在这里 http://bling.github.io/blog/2009/09/07/member-injection-module-for-autofac/

有效,但我不喜欢它:)

在这种情况下我不想使用构造函数注入.

谢谢.

Jos*_*ose 13

这将加载所有继承ViewModelBase并仅注入所需特定属性的类.很多时候,您不希望注入子类的其他属性.

builder.RegisterAssemblyTypes( GetType().Assembly )
    .AssignableTo<ViewModelBase>()
    .OnActivated( args =>
    {
        var viewModel = args.Instance as ViewModelBase;
        if( viewModel != null )
        {
            viewModel.MyProp = args.Context.Resolve<ISomeClass>();
        }
    } );
Run Code Online (Sandbox Code Playgroud)

  • 如果你想保持属性注入有限而不打开所有子类(当原因仅仅是为了避免更改许多构造函数),这是一个很好的答案. (2认同)

Pet*_*old 7

您必须确保MainViewModel使用属性注入注册了viewmodel类.目前,您已注册财产注册的所有内容都是ViewModelBase,但请考虑您正在解决的问题.你永远不会解决ViewModelBase,你正在解决问题MainViewModel.这就是需要在容器中注册的内容.

尝试:

builder.RegisterType<MainViewModel>().PropertiesAutowired();
Run Code Online (Sandbox Code Playgroud)