加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net-mvc-3 – 我应该将我的实用程序类放在ASP.NET MVC3应用

发布时间:2020-12-15 22:17:10 所属栏目:asp.Net 来源:网络整理
导读:我正在使用C#和Razor在ASP.NET MVC3中开发一个Web应用程序. 我需要创建一个实用程序类,我在其中放置函数将字符串转换为日期(年,月,日等等). 在ASP.NET Web窗体中,我曾经将这种类放在App_Code文件夹中.在MVC中没有这样的文件夹,我不认为实用程序类既不属于Mod
我正在使用C#和Razor在ASP.NET MVC3中开发一个Web应用程序.

我需要创建一个实用程序类,我在其中放置函数将字符串转换为日期(年,月,日等等).

在ASP.NET Web窗体中,我曾经将这种类放在App_Code文件夹中.在MVC中没有这样的文件夹,我不认为实用程序类既不属于Models也不属于Helpers(我创建的文件夹,用于将我的扩展放在HTML Helpers上).

我读到将实用程序类放在不同的程序集中是一种很好的做法.我想一个不同的项目应该做的工作,但我应该创建什么样的项目?普通的类库项目对我来说似乎是最合乎逻辑的选择.

但是在我的情况下,我只需要使用多个方法放置一个单独的类,因此,如果我们忽略了可重用性,那么将实用程序类放在我的MVC3 Web应用程序中的某个地方是不是更合乎逻辑?

解决方法

你不应该有实用程序类.将它们转换为更好的扩展方法.查看模型甚至更好.

我经常为管道创建一个名为“HtmlHelpers”或“Infrastructure”的文件夹.

“Common”文件夹就像垃圾桶imho.你把所有的垃圾都放进去了.

更新

我将它放在DateTime的扩展方法中(放在名为DateTimeExtensions的类中,该类放在名为Infrastructure的名称空间中).

我会在视图模型内部或在生成视图模型时(在控制器中)使用它.

至于哪个项目,它并不重要.重要的是你得到了具有特定任务(或职责)的小班.

有些人认为你应该有几个具有不同职责的类库.我不这样做.我为业务逻辑创建了一个UI项目和一个项目.但是,我确保这些类实现了一个或多个接口,以便以后能够重构应用程序. KISS也应该适用于项目结构,而不仅仅是其中的代码.

换句话说:我会将我的助手放在Core(业务逻辑项目)中名为Infrastructure的名称空间中.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读