AJAX を使用してカスタム バリデーターを実装しましたが、正常に動作します。
編集済み。ASPX コードを追加
<asp:DetailsView ID="DetailsView" runat="server" Height="50px" Width="25em" DataSourceID="SqlDataSource1" AutoGenerateRows="False" DefaultMode="Insert" CellPadding="4" ForeColor="#333333" GridLines="None" OnItemInserting="DetailsView_ItemInserting">
<Fields>
<asp:TemplateField HeaderText="Nombre *">
<InsertItemTemplate>
<asp:TextBox ID="txtNombre" runat="server" Text='<%# Bind("nombre) %>'></asp:TextBox>
<asp:RequiredFieldValidator ID="requireNombre" runat="server" ControlToValidate="txtNombre" ErrorMessage="El campo 'Nombre' no puede estar vacío." ValidationGroup="DetailsGroup" Display="None"></asp:RequiredFieldValidator>
<asp:CustomValidator id="CustomValidator1" ControlToValidate="txtNombre" ClientValidationFunction="validateNombre" ValidationGroup="DetailsGroup" Display="none" ErrorMessage="Introduzca un nombre diferente." runat="server"/>
</InsertItemTemplate>
</asp:TemplateField>
</Fields>
</asp:DetailsView>
関数 AJAX:
function validateNombre(src, args) {
var isValid;
$.ajax({
type: "POST",
url: "Nombre.aspx/ComprobarNombre",
data: "{'nombre': '" + args.Value + "'}",
contentType: "application/json; charset=utf-8",
dataType: "json",
async: false,
success: function (msg) {
isValid = msg.d;
}
});
args.IsValid = isValid;
ComprobarNombre: [WebMethod()]
public static bool ComprobarNombre(string nombre)
{
/* SQLConnections... */
if(...)
return false;
else
return true;
}
問題は、TextBox に値を入力するたびに AJAX 関数が起動されることです。フォームのボタンをクリックしたときにのみ関数を起動する必要があります。