在我正在处理的应用程序上,我要求在点击某个按钮时,验证会触发一些相关的文本框;如果它们没有通过,则不会发生任何事情,否则会发生从AJAX调用触发的操作。这个AJAX调用返回一些关于操作成功的消息。
我的部分观点发生在看起来有点像这样:
<div>
<div id='cell-phone'>
@Model.ValidationMessageFor(x=>x.Model.CellNumber)
@Model.TextBoxFor(x=>x.Model.CellNumber)
</div>
<div id='pager'>
<!-- Ditto, only x.Model.Pager; yes, some people use pagers still. -->
</div>
<div id='page-address'>
<!-- ... x.Model.PageAddress ... -->
</div>
<div id='pager-test'>
<a href='#' id='test-pager' class='button'>Test</a>
<span id='test-result'></span>
</div>
</div>
<script>
var $cellNum = $('#cell-phone input'),
$pagerNum = $('#pager input'),
$pageAddress = $('#page-address input'),
$testPager = $('#pager-test'),
$testResult = $('#test-result');
$(document).ready(function () {
$testPager.click(function () {
pagerTest();
});
});
function pagerTest() {
var args = { address: $pageAddress.val() };
$.getJSON('@Url.Action("SendTestPage")', args, function(result) {
$testResult.html(result.Message);
});
}
</script>
......在服务器级别下来......
public JsonResult SendTestPage(string address)
{
// SNIP: Other unnecessary details.
var result = new EmailSendResult
{
success = SendEmailMethod(address)
};
result.message = result.success
? "Message sent!"
: "Couldn't send message...";
return result;
}
....
public class EmailSendResult
{
public bool success;
public string message;
}
问题:虽然我能够获得消息/成功值,但我还需要激活View Model的验证。我不知道如何使用AJAX调用来做到这一点。我怀疑是A)我正在使用错误的工具来完成工作,或者B)我正在使用合适的工具完成一项工作,但我还需要其他工具。我错过了什么才能导致验证开火?
答案 0 :(得分:2)
当您点击“test-pager”链接时,系统会调用该操作,但不会触发您的表单验证,因为您的链接不是提交。如果要验证工作,您必须在表单上有一个提交按钮。当用户单击它时,将启动验证。因此,将测试寻呼机更改为以下内容:
<input type="submit" id="test-pager" class="button" />
答案 1 :(得分:-1)
或者(如果我理解正确的话)你可以绑定地址文本框更改事件,并在其中调用testPage函数。