ホームページ > ウェブフロントエンド > jsチュートリアル > MVCのフォームデータを介してモデルオブジェクト全体を渡すにはどうすればよいですか?

MVCのフォームデータを介してモデルオブジェクト全体を渡すにはどうすればよいですか?

Barbara Streisand
リリース: 2024-12-20 03:54:10
オリジナル
733 人が閲覧しました

How to Pass Entire Model Objects via Form Data in MVC?

MVC のフォーム データからモデル オブジェクト全体を取得する

モデル オブジェクト全体をフォーム データ経由で渡すときは、それらが正しく変換されていることを確認することが重要ですコントローラのモデルタイプに合わせてください。これを実現する方法は次のとおりです:

JavaScript の実装:

個別のプロパティを手動で追加するのではなく、FormData を利用してモデル全体をシリアル化します:

var formdata = new FormData($('form').get(0));
ログイン後にコピー

これには、 form.

Ajax リクエスト:

Ajax を使用してフォーム データを投稿し、自動処理とコンテンツ タイプの設定を無効にします:

$.ajax({
  url: '@Url.Action("YourActionName", "YourControllerName")',
  type: 'POST',
  data: formdata,
  processData: false,
  contentType: false,         
});
ログイン後にコピー

コントローラーアクション:

コントローラーで、次のアクションを定義します。モデルをパラメータとして受け入れます:

[HttpPost]
public ActionResult YourActionName(YourModelType model)
{
    // Perform operations on the model...
}
ログイン後にコピー

または、モデルにファイル入力が含まれている場合、2 番目のパラメータはファイル プロパティの HttpPostedFileBase である必要があります:

[HttpPost]
public ActionResult YourActionName(YourModelType model, HttpPostedFileBase myImage)
{
    // Handle file and perform operations on the model...
}
ログイン後にコピー

Additionalデータ付加:

必要に応じて、追加のプロパティをフォーム データに追加できます。使用:

formdata.append('someProperty', 'SomeValue');
ログイン後にコピー

以上がMVCのフォームデータを介してモデルオブジェクト全体を渡すにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート