Reputation: 3754
At the moment I am trying to get into the ASP.NET MVC framework.
For most of my test applications I used a single assembly/project. This worked fine for some smaller applications. Then I wondered how I could place my model, controller and view classes into separate assemblies? In really big web-applications it is not very realistic to put everything into a single assembly/project.
So my question is: Is it possible to tell the ASP.NET MVC framework to search in another assembly for views and/or controllers without losing the built-in flexibility of the routing engine?
Upvotes: 12
Views: 8366
Reputation: 7220
Only completing @David's answer:
If your project is managed by NuGet
, after creating the class libraries, perform a copy of your packages.config
file to the class libraries root. Afterwards, you should edit each packages.config
file adding or removing packages, according to the needs of each class library.
Upvotes: 0
Reputation: 14585
I realize that this is a really old question but I have written an article on how to exactly what you are asking for
Upvotes: 1
Reputation: 15360
(unknown) is correct. Create two projects, a class library and an MVC web project. The MVC project should reference the class library that contains the controllers and code behind files (global asax etc). Here is an example layout.
The class library should only contain .cs files and no views (.aspx/.ascx files).
MyProject.BaseSite (class library) + Controllers - HomeController.cs - ... any other controllers - default.aspx.cs - global.asax.cs
MVC web project should contain configs, views etc and a reference to your class library
MyProject.ExampleSite + Content + scripts + css + images + Views + Home - index.aspx - .. other aspx files + Shared - Site.master - web.config
Remember the different namespaces. You can then create multiple Example websites that reference the same code. This allows you to effectively skin your website completely differently.
Upvotes: 6
Reputation: 4854
Yes, if you use one of the supported dependency injection containers, then their configuration data typically specify not only the class to be loaded in response to a particular query, but also the assembly from which it is to be loaded. This allows you to split your classes up across arbitrary assemblies and MVC will still be able to find them.
Although, of course, the simpler answer provided by Unknown (Google) will also work!
Upvotes: 1
Reputation: 82096
Create a separate class library project for each layer of responsibility, compile to create the assembly and then reference each in your application where appropriate.
Upvotes: 2