use*_*903 6 c# jquery json asp.net-mvc-3
请记住,我对MVC,Json,jQuery等的工作方式比较新,所以请耐心等待.我过去5年一直在做Web Forms ...
我正在努力验证Modal弹出窗口中的表单,该窗体使用JsonResult方法将表单数据发布到服务器.我希望我可以在弹出窗口中加载一个部分视图并完成它,但这不是一个选项.
无论如何,我有一些代码在昨天工作,但在我用Git进行拉/推之后,我的验证出了点问题.在我将任何内容传递给服务器(必填字段,正确的数据类型等)之前,我使用常规JavaScript进行一些基本验证,但有些事情,比如确保用户输入的名称是唯一的,需要我一路走对业务逻辑.
在浏览互联网之后,我发现如果你想让jQuery在AJAX请求中识别来自JsonResult的错误,你必须发送一个错误性质的HTTP状态代码.我相当肯定它可以是400或500的任何数字,它应该工作......它确实......到了一定程度.
我要做的是使用Response.StatusCode和设置状态代码和状态描述Response.StatusDescription,然后返回模型.jQuery会识别错误,然后它会显示我在状态描述中设置的错误消息.一切都很好.
今天,似乎从我的控制器中的JsonResult到我的jQuery的唯一原因是状态代码.我已经跟踪了c#并且所有内容似乎都设置正确,但我似乎无法提取我设置的自定义状态描述.
这是我的代码:
模态弹出窗口
<fieldset id="SmtpServer_QueueCreate_Div">
@Form.HiddenID("SMTPServerId")
<div class="editor-label">
@Html.LabelFor(model => model.ServerName)
<br />
<input type="text" class="textfield wide-box" id="ServerName" name="ServerName" title="The display name of the Server" />
<br />
<span id="ServerNameValidation" style="color:Red;" />
</div>
<div class="editor-label">
<span id="GeneralSMTPServerValidation" style="color:Red;" />
</div>
<br />
<p>
<button type="submit" class="button2" onclick="onEmail_SmtpServerQueueCreateSubmit();">
Create SMTP Server</button>
<input id="btnCancelEmail_SmtpServerQueueCreate" type="button" value="Cancel" class="button"
onclick="Email_SmtpServerQueueCreateClose();" />
</p>
</fieldset>
Run Code Online (Sandbox Code Playgroud)
控制器
[HttpPost]
public virtual JsonResult _QueueCreate(string serverName)
{
Email_SmtpServerModel model = new Email_SmtpServerModel();
string errorMessage = "";
try
{
Email_SmtpServer dbESS = new Email_SmtpServer(ConnectionString);
model.SMTPServerId = System.Guid.NewGuid();
model.ServerName = serverName;
if (!dbESS.UniqueInsert(model, out errorMessage))
{
return Json(model);
}
}
catch (Exception ex)
{
errorMessage = ex.Message;
}
Response.StatusCode = 500;
Response.StatusDescription = errorMessage;
return Json(model);
}
Run Code Online (Sandbox Code Playgroud)
jQuery Ajax请求
$.ajax({
type: 'POST',
data: { ServerName: serverName },
url: getBaseURL() + 'Email_SmtpServer/_QueueCreate/',
success: function (data) { onSuccess(data); },
error: function (xhr, status, error) {
$('#GeneralSMTPServerValidation').html(error);
}
});
Run Code Online (Sandbox Code Playgroud)
就像我昨天提到的那样,这向用户显示了一条很好的信息,通知他们输入的名称如果碰巧存在则不是唯一的.现在,我得到的只是一个"内部服务器错误"消息......这是正确的,因为这是我在设置状态代码时发送的内容.但是,就像我提到的那样,它不再看到我发送的自定义状态描述.
我也尝试将其设置为一些未使用的状态代码以查看是否存在问题,但这只是没有显示任何内容,因为它不知道要显示的文本.
谁知道?也许我的代码现在出了问题.最有可能是在其他地方做出改变,可能是什么,我不知道.有没有人对可能出现的问题有任何想法?
如果您需要更多代码,我会尽力提供.
谢谢!
Nic*_*yle 10
在您的错误回调中,尝试使用
xhr.statusText
Run Code Online (Sandbox Code Playgroud)
此外,如果您使用的是Visual Studio的Web服务器,则可能无法获取状态文本. http://forums.asp.net/post/4180034.aspx
| 归档时间: |
|
| 查看次数: |
2816 次 |
| 最近记录: |