gcs*_*cso 5 c# dependency-injection ninject
我目前有一个工厂,它依赖于一些参数来正确决定返回哪个对象.这家工厂还没有受到DI的约束.据我所知,NInject使用提供者作为工厂.
这是我现在拥有的.我会警告你,它不漂亮.
public interface IRole
{
string Name { get; }
}
public class FooRole : IRole
{
public string Name { get { return "Foo Role"; } }
}
public class BarRole : IRole
{
public string Name { get { return "Bar Role"; } }
}
public class FooBarRoleModule : NinjectModule
{
public override void Load()
{
Bind<IRole>().ToProvider<RoleProvider>();
}
}
public class RoleProvider : Provider<IRole>
{
protected override IRole CreateInstance(IContext context)
{
var isNewParameter = context.Parameters
.Where(x => x.Name == "isNew")
.Select(x => x.GetValue(context))
.Cast<bool>()
.FirstOrDefault();
if (isNewParameter) return new FooRole();
return new BarRole();
}
}
var role = kernel.Get<IRole>(new ConstructorArgument("isNew", true));
Console.WriteLine(role.Name);
Run Code Online (Sandbox Code Playgroud)
我几乎可以肯定这不是动态注入依赖项的正确方法,但它确实有效.坦率地说,看看我一起入侵的东西似乎没有多大意义.
我需要动态解决依赖关系的原因是,在应用程序的生命周期中,最终用户可以承担多个角色.上面公布的样本非常简单,但参数(目前只有新的)将决定是否反对注入.
在运行时使用参数未知的提供程序的正确方法是什么?只要用户触发可以赋予它们不同角色的代码,就会传入这些参数.
谢谢.
public class RoleFactory : IRoleFactory
{
public IRole Create(bool isNew)
{
if (isNew) return new BarRole();
return new FooRole();
}
}
Run Code Online (Sandbox Code Playgroud)
绑定它Bind<IRoleFactory>().To<RoleFactory>();并像这样使用它.
var role = kernel.Get<IRoleFactory>();
Console.WriteLine(role.Create(true).Name);
Run Code Online (Sandbox Code Playgroud)
这个修改后的版本确实看起来更好,更有意义,但我相信我错过了你帖子中的一些关键细节.想要添加,isNew如果从例如"创建新事件"按钮调用工厂,则参数将为true.
Ninject提供了几种机制来处理这些问题.哪一个最适合您,取决于确切的问题.以下是最有可能的:
使用命名绑定:
kernel.Bind<IRole>().To<FooRole>().Named("old");
kernel.Bind<IRole>().To<BarRole>().Named("new");
kernel.Get<IRole>("new");
Run Code Online (Sandbox Code Playgroud)
使用条件绑定
kernel.Bind<IRole>().To<AdminRole>().When(ctx => UserHasAdminPermission())
kernel.Bind<IRole>().To<UserRole>();
kernel.Get<IRole>();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
317 次 |
| 最近记录: |