繁体   English   中英

将FormData从Angular传递到.NET MVC控制器

[英]Pass FormData from Angular to .NET MVC Controller

我的观点:

<form ng-submit="onFormSubmit()">
    <div class="form-group">
        <label for="Movie_Genre">Genre</label>
        @Html.DropDownListFor(m => m.Movie.GenreId, new SelectList(Model.Genres, "Id", "Name"), "Select Genre", new { @class = "form-control", ng_model = "formData.Movie.GenreId" })
        @Html.ValidationMessageFor(m => m.Movie.GenreId, "The Genre field is required.")
    </div>
    <div class="form-group">
        <label for="Movie_Stock">Number in Stock</label>
        @Html.TextBoxFor(m => m.Movie.Stock, new { @class = "form-control", ng_model = "formData.Movie.Stock" })
        @Html.ValidationMessageFor(m => m.Movie.Stock)
    </div>

    @Html.HiddenFor(m => m.Movie.Id, new { ng_model = "formData.Movie.Id" })
    @Html.AntiForgeryToken()
    <button type="submit" class="btn btn-primary">Save</button>
</form>

我的角度控制器:

var MoviesAdminEditController = function ($scope, $state, $http) {
    $scope.formData = {};

    $scope.onFormSubmit = function () {
        // $scope.formData.__RequestVerificationToken = angular.element('input[name="__RequestVerificationToken"]').attr('value');

        var formData = new FormData(angular.element('form'));
        formData.append('__RequestVerificationToken', angular.element('input[name="__RequestVerificationToken"]').attr('value'));

        $http({
            method: 'POST',
            url: '../../Movies/Save',
            data: formData,
            headers: {
                'enctype': 'multipart/form-data'
            }
        }).then(function successCallback(response) {
            alert('worked');
            $state.go('moviesAdmin');
        }, function errorCallback(response) {
            alert('failed');
            $state.go('moviesAdmin');
        });
    }
}

因此,当尝试使用Angular将数据从前端发送到后端.Net控制器中的ActionResult时,遇到了很多问题。

  1. 当我使用$ http对象发送$ scope.formData(它会自动加载)时,.Net无法识别数据,因为它没有被格式化为期望的表格数据。

  2. 当我使用FormData JS对象时,出现服务器错误:“无效的JSON原语:------ WebKitFormBoundaryzFvk65uKpr0Z7LG1。”

  3. 如果我对FormData对象进行字符串化处理,我们将解决第一个问题。

许多其他来源/问题表明,仅将FormData对象传递给ajax请求就应该起作用-没有关于为什么发生2错误的信息。

有人知道为什么这会让人高兴吗?

没有人提出解决方案,但幸运的是我做到了。 您需要使用jquery $ .ajax方法,该方法接受Angular的$ http不接受的可选参数。 最终代码如下所示:

var formData = new FormData(angular.element('#new-movie-form')[0]);

$.ajax({
    type: 'POST',
    data: formData,
    url: '../../Movies/Save',
    processData: false,
    contentType: false,
    cache: false,
    dataType: 'json'
})
.done(function () {
    alert('success');
    $state.go('moviesAdmin');
})
.fail(function () {
    alert('failed');
    $state.go('moviesAdmin');
});

感谢这篇文章 ,这有助于清除其中的一些内容。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM