🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
アーキテクチャ

アーキテクチャとは、情報システム(ハードウェア、OS、アプリケーション、ネットワーク等)の設計方法、設計思想、設計思想に基づいて構築されたシステム構造をアーキテクチャと呼びます

ASP.NET

ASP.NETは動的なWebサイトやWebアプリケーション、そしてWebサービスを構築出来るようにする為、Microsoftによって開発されたウェブアプリケーション開発フレームワークです。

Q&A

1回答

1783閲覧

ASP.NET MVC 画面特有のロジックはどこに書くべき

退会済みユーザー

退会済みユーザー

総合スコア0

アーキテクチャ

アーキテクチャとは、情報システム(ハードウェア、OS、アプリケーション、ネットワーク等)の設計方法、設計思想、設計思想に基づいて構築されたシステム構造をアーキテクチャと呼びます

ASP.NET

ASP.NETは動的なWebサイトやWebアプリケーション、そしてWebサービスを構築出来るようにする為、Microsoftによって開発されたウェブアプリケーション開発フレームワークです。

0グッド

0クリップ

投稿2021/01/30 06:10

編集2021/01/30 06:13

MVCでいうと、ビジネスロジックはModelクラスに書くべきですが、
Modelクラスは汎用的であるべきだと思います。

ですが、開発を進めているとその画面特有の処理があると思います。

例えば
・A画面では登録後にメールを送る、B画面では登録後にメールは送らない等

これをModelクラスにそれぞれ実装してしまうと、汎用性が失われてしまいます。
こういった画面特有の処理はControllerクラスに書くべきでしょうか?

それとも、別途、画面特有の処理をするレイヤーを用意してそこに書くべきなのでしょうか。

例えば、以下の様な形で、ControllerとModelの間に画面特有のビジネスロジックを書くレイヤーを用意する
Controller → ViewService → Model → DataAccess

やっぱりControllerに書くとテストがしにくいし、[Controller]といっているのにその役割を超えてしまっている気もます><

そう考えると、やっぱり画面特有のビジネスロジックを書くレイヤーを用意するのがいい気がするのですが、あまりそうしている話を聞いたことがなく不安です><

どうかお知恵を貸して頂ければ幸いです...!
どうぞ宜しくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2021/06/24 01:10 編集

ここのコメントは回答欄に移動しました
退会済みユーザー

退会済みユーザー

2021/07/21 00:25

質問者さん、無言ですが、自分で立てたスレッドを放置しておかないで、回答に対するフィードバックを書いて、クローズするところまでちゃんとやってください。無言で放置はすべての閲覧者・回答者に失礼。
guest

回答1

0

ASP.NET MVC でいう「モデル」について理解がちょっと違うような気がしますので、それを書いた記事を紹介しておきます。

ASP.NET MVC の Model
http://surferonwww.info/BlogEngine/post/2020/05/29/model-in-aspnet-mvc.aspx

モデルの話はともかくとして、質問の件は組織のルールに従うか、ルールが無ければ質問者さんが属する組織内で話し合ってルールを決めてそれに従うという話になると思います。

質問者さんが組織に属してなくて、開発から保守まで自分一人でやるということなら、自分のやりやすいようにやってはいかがという話になると思います。

なので、ここのような掲示板での話は、ごくごく具体的な問題・課題とそれを解決するための手段の話でないと、あまり実のある話にはなりそうもないと個人的には思います。

投稿2021/06/24 01:09

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問