【发布时间】:2011-09-17 13:47:19
【问题描述】:
关于从表单/div 中获取输入字段并将它们发送到服务器端控制器的各种帖子都有。我不清楚的是如何在控制器上接受输入。
我尝试了各种方法:
function SendEMail( vThis )
{
var vInput = $("#idEMailFields *").serializeArray();
$.ajax({
url: '@Url.Action( "SendEMail", "TournMaint")',
data: JSON.stringify(vInput),
type: 'POST',
contentType: 'application/json; charset=utf-8;',
dataType: 'json',
success: function (response)
{
$("#idEMailResponse").html(response);
return;
},
error: function( xhr, status, error )
{
debugger;
var verr = xhr.status + "\r\n" + status + "\r\n" + error;
alert( verr );
}
});
}
控制器的样子:
[HttpPost]
public JsonResult SendEMail( CNameValue [] inputs )
{
String sView = "EMail messages queued";
return Json( sView, JsonRequestBehavior.AllowGet );
}
CNameValue 类是我自己创建的,因为我没有找到可以做同样事情的标准。应该有一个标准的字典类,可以按名称选择参数?我的问题是这应该怎么做??
第二个变体:
function SendEMail( vThis )
{
var params = {};
var v1 = $("#idEMailFields input[name=EMailAddressing], #idEMailFields input[type=hidden],#idEMailFields textarea");
$(v1).each( function(index)
{
params[this.name]=this.value;
});
$.ajax({
url: '@Url.Action( "SendEMail", "TournMaint")',
data: JSON.stringify(params),
type: 'POST',
contentType: 'application/json; charset=utf-8;',
dataType: 'json',
success: function (response)
{
debugger;
return;
},
error: function (x)
{
debugger;
alert(x.status);
}
});
}
控制器的样子:
[HttpPost]
public JsonResult SendEMail( Int32 TournamentId, String EMailText, String EMailAddressing )
{
String sView = "return something usefull";
return Json( sView, JsonRequestBehavior.AllowGet );
}
这是将数据移动到服务器的好方法,但它很容易受到剃刀标记变化的影响,从而导致控制器崩溃。我知道你永远不会摆脱这个问题,但减少可能性是一个想法。
将屏幕数据获取到服务器端控制器的最佳方式是什么?
【问题讨论】:
标签: jquery ajax asp.net-mvc razor