web-dev-qa-db-fra.com

Comment ajouter un ensemble complet de modèle à formdata et l'obtenir dans MVC

Comment puis-je transmettre un objet de modèle d'ensemble via formdata et le convertir en type de modèle dans le contrôleur?

Ci-dessous est ce que j'ai essayé!

Partie JavaScript:

model = {
             EventFromDate: fromDate,
             EventToDate: toDate,
             ImageUrl: imgUrl,
             HotNewsDesc: $("#txthtDescription").val().trim(),
        };
formdata.append("model",model);

puis passez-le par AJAX, ce sera une chaîne, et si je vérifie la valeur de Request.Form["model"], le résultat sera identique, c'est-à-dire qu'il sera reçu sous forme de chaîne et que la valeur sera "[object object]"

Est-il possible de passer modèle à travers formdata et le recevoir dans le contrôleur?  

53
Guruprasad Rao

Si votre vue est basée sur un modèle et que vous avez généré les contrôles à l'intérieur des balises <form>, vous pouvez sérialiser le modèle en FormData à l'aide de

var formdata = new FormData($('form').get(0));

Cela inclura également tous les fichiers générés avec <input type="file" name="myImage" .../>

et le poster en utilisant

$.ajax({
  url: '@Url.Action("YourActionName", "YourControllerName")',
  type: 'POST',
  data: formdata,
  processData: false,
  contentType: false,         
});

et dans votre contrôleur

[HttpPost]
public ActionResult YourActionName(YourModelType model)
{
}

ou (si votre modèle n'inclut pas de propriété pour HttpPostedFileBase)

[HttpPost]
public ActionResult YourActionName(YourModelType model, HttpPostedFileBase myImage)
{
}

Si vous souhaitez ajouter des informations supplémentaires qui ne figurent pas dans le formulaire, vous pouvez les annexer à l'aide de

formdata.append('someProperty', 'SomeValue');
76
user3559349

Si vous souhaitez envoyer des données de formulaire à l’aide d’Ajax. C’est le moyen d’envoyer 

var formData = new FormData();

//File Upload
   var totalFiles = document.getElementById("Iupload").files.length;


for (var i = 0; i < totalFiles; i++) {
    var file = document.getElementById("Iupload").files[i];

    formData.append("Document", file);
}

formData.append("NameCode", $('#SelecterID').val());
formData.append("AirLineCode", $('#SelecterID').val());


$.ajax({
        url: "/Controller/ActionName",
        type: "POST",
        dataType: "JSON",
        data: formData,
        contentType: false,
        processData: false,
        success: function (result) {
    }
})
16
user3824027

Du côté de la vue, si vous utilisez ajax alors,

$('#button_Id').on('click', function(){
        var Datas=JSON.stringify($('form').serialize());
        $.ajax({
            type: "POST",
            contentType: "application/x-www-form-urlencoded; charset=utf-8",
            url: '@Url.Action("ActionName","ControllerName")',
            data:Datas,
            cache: false,
            dataType: 'JSON',
            async: true,
            success: function (data) {

            },
        });
    });

Du côté du contrôleur,

 [HttpPost]
 public ActionResult ActionName(ModelName modelObj)
 {
 //Some code here
 }
0
Sam