请原谅我的无知,但我对IOC和NinJect很新.我已经搜索了高低的易于理解的解决方案,但到目前为止他们已经找不到我了.
到目前为止,我有以下所有工作正如预期:
private class StandardModule : NinjectModule
{
public override void Load()
{
Bind<ILog>().To<NLogLogger>(); // Use NLog
Bind<IMyEntityFrameWorkRepository().To<MyEntityFrameWorkRepository>();
}
}
Run Code Online (Sandbox Code Playgroud)
然后,MyEntityFrameWorkRepository通过app/web.config中声明的连接字符串创建自己的EF DbContext:
public class MyDbContext : DbContext
{
public MyDbContext() : base("MyAppConfig")
{
}
........
}
Run Code Online (Sandbox Code Playgroud)
然而!!我的目标是这样的 - 我意识到这种语法是"胡说八道"(我想我也可能需要IOC MyDbConext),但我希望"伪代码"传达我的愿望:
private class StandardModule : NinjectModule
{
public override void Load()
{
Bind<ILog>().To<NLogLogger>(); // Use NLog
string mySqlConnectionString = MyApp.GetCommandLineArgument("sqlconn"); // "Data Source=..."
Bind<IMyEntityFrameWorkRepository().To<MyEntityFrameWorkRepository>(mySqlConnectionString);
}
}
.................
public class MyDbContext : DbContext
{
public MyDbContext( string sqlConnectionString) :
base(sqlConnectionString) …Run Code Online (Sandbox Code Playgroud)