在asp.net mvc(4)中,开箱即用,视图进入 Views
文件夹,然后由子文件夹中的控制器分组 .
控制器进入 Controllers
文件夹,(查看/编辑/输入)模型进入 Models
文件夹等 .
我喜欢视图的组织方式 . 但是,我不喜欢水平地打破其余的MVC片段 .
我的问题是,将视图组织结构保持原样会有什么缺点,但是按控制器(即用例)对其他类进行分组 . 例如 . :
/Home
HomeController.cs
IndexViewModel.cs
IndexViewModelBinder.cs
/Messages
MessagesController.cs
MessagesApiController.cs
MessagesViewModelBinder.cs
MessageViewModel.cs
MessagesListViewModel.cs
/Views
/Home
Index.cshtml
/Messages
MessagesIndex.cshtml
MessageDetails.cshtml
2 回答
重要的是View文件的排列,因为它们是在运行时访问的 . 其他所有内容都被编译到程序集中,因此源文件的物理位置无关紧要 .
像你一样,我发现大型项目的默认安排有点尴尬,所以这就是我如何布置我当前的项目:
所以基本上,我将我的ViewModel类放在与视图相同的文件夹中,而不是将所有ViewModel放在一起(这使得逻辑意义不大) . 我很想把我的控制器放在他们的视图文件夹中,但我决定反对它 .
到目前为止,我发现我的方法没有任何缺点(现在使用它差不多2年了) .
我通常喜欢避免可能的区域,因为它会产生一些路由问题 .
我认为你的结构完全没问题(并且优于基于“类型”分离代码的默认MVC / Web结构,而不是“功能”) .
我建议你只在web DLL中保存你的“web”.cs文件(例如Controllers,ViewModels,Binders等),并在Domain / Services / etc层的单独DLL中使用相同的结构,这样它们就可以了如果/根据需要,可以单独重复使用/测试 .