[英]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时,遇到了很多问题。
当我使用$ http对象发送$ scope.formData(它会自动加载)时,.Net无法识别数据,因为它没有被格式化为期望的表格数据。
当我使用FormData JS对象时,出现服务器错误:“无效的JSON原语:------ WebKitFormBoundaryzFvk65uKpr0Z7LG1。”
如果我对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.