我解决了这个问题。不是一个优雅的解决方案,但它有效。
首先我把代码放到页面上的一个div中
<div align="right"><asp:CustomValidator ID="RowValidator" runat="server"
ErrorMessage="Total of #total# does not equal 1st Preference + Ticket"
ControlToValidate="Total" ValidateEmptyText="True"
ClientValidationFunction="CheckRow" SetFocusOnError="True" EnableClientScript="True"
enableViewState="False" Display="Dynamic"></asp:CustomValidator></div>
然后我创建了一个 JavaScript 函数......
function CheckRow(sender,args) {
// get the name of the control to validate
try {
args.IsValid = true;
ctv = sender.controltovalidate;
// get the data from the other controls
nt = document.getElementById(ctv.replace('_Total','_NonTicket'));
t = document.getElementById(ctv.replace('_Total','_Ticket'));
if (nt && t) {
v1 = Number(nt.value);
v2 = Number(t.value);
v3 = Number(args.Value);
if ((v1 + v2) != v3){
msg = GetMessage(sender);
sender.innerHTML = msg.replace("#total#",Number(args.Value));
args.IsValid = false;
return false;
}
}
}
catch (e) {
// something wrong default to server side validation
}
return true;
}
这是由自定义验证器为每一行调用的,我使用发送者的 controltovalidate 参数来获取名称
然后是一些字符串操作来获取其他字段的名称。
检索到后,您可以做自己喜欢的事情,在我的情况下,我会添加和比较。如果出现错误,则清除 Isvalid 标志并修改消息以适合。
getmessage 函数是必需的,因为我更改了消息以提供更有意义的错误消息
/*
get the error message from the validator
store it so it can be retrieved again
this is done because the message is altered
*/
function GetMessage(sender){
msg = window[sender.id+"_msg"];
if (!msg){
msg = sender.innerHTML;
window[sender.id+"_msg"] = msg;
}
return msg;
}
getmessage 函数保留原始消息的副本,因此如果用户多次出错,则可以以原始形式检索消息,否则在我们第一次编辑消息时,我们会覆盖占位符 (#total#)。
直流