5

所以我一直在寻找,似乎找不到类似的问题。

基本上,似乎 usingCompareValidator没有RequiredFieldValidator.

<div class="control-group">
                <label class="control-label" for="PositionName">
                    Password:</label>
                <div class="controls">
                    <asp:TextBox ID="txtPassword" runat="server" TextMode="Password"></asp:TextBox>
                    <%--<asp:RequiredFieldValidator ID="rvPassword" runat="server" ControlToValidate="txtPassword"
                        ErrorMessage="Please Enter Password" SetFocusOnError="True" ValidationGroup="1"
                        CssClass="error"></asp:RequiredFieldValidator>--%>
                </div>
            </div>
            <div class="control-group">
                <label class="control-label" for="PositionName">
                    Confirm Password:</label>
                <div class="controls">
                    <asp:TextBox ID="txtConfirmPassword" runat="server" TextMode="Password"></asp:TextBox>
                    <asp:RequiredFieldValidator ID="reqConPass" runat="server" ControlToValidate="txtConfirmPassword"
                        ErrorMessage="Please Enter Confirm Password" SetFocusOnError="True" ValidationGroup="1"
                        CssClass="error"></asp:RequiredFieldValidator>
                    <asp:CompareValidator ID="compPassword" runat="server" ControlToValidate="txtConfirmPassword"
                        ControlToCompare="txtPassword" ErrorMessage="Password Mismatch" SetFocusOnError="True"
                        ValidationGroup="1" CssClass="error"></asp:CompareValidator>
                </div>
            </div>

基本上,你可以看到我已经RequiredFieldValidator注释掉了通过和确认通过。当我这样做时,我只能在 中提交一个值,txtPassword textbox而在txtConfirmPassword textbox.

如果我取消注释,RequiredFieldValidators那么它应该进行比较。

如果有帮助,我需要这样做的原因是因为我无法解密密码并用他们当前的密码自动填充文本框。因此,每当编辑用户时,他们每次都需要输入一个新密码,并RequiredFieldValidator在其上添加一个。

所以我的解决方案是摆脱RequiredFieldValidator并检查文本是否为空或为空,如果是,则不要更新密码,但如果不是,则在不更新密码的情况下更新用户。

我希望这是有道理的,如果有人可以提供帮助,我将不胜感激。

如果您需要更多信息,请询问。

再次感谢!

4

2 回答 2

0

请参阅此代码片段,在第一个密码中,我使用了正则表达式验证器,一旦密码有效,我就启用了比较验证器。

 <script>
        function Validate() {            
            if (document.getElementById('<%=txtPassword.ClientID %>').value != "")
                ValidatorEnable(document.getElementById('<%=ConfirmPasswordRequired.ClientID %>'), true);
            else
                ValidatorEnable(document.getElementById('<%=ConfirmPasswordRequired.ClientID %>'), false);
        }
    </script>
	<p>
              Password
                <asp:TextBox ID="txtPassword" runat="server" TextMode="Password"></asp:TextBox>
               
                <asp:RegularExpressionValidator ID="PasswordRegularExpression" runat="server"
                    ErrorMessage="*Password must be at least 8 characters long and include at least one Special Character, one Number, and one Capital letter."
                    ValidationGroup="ValidationGroup1" ValidationExpression="^.*(?=.{8,})(?=.*\d)(?=.*[a-z])(?=.*[A-Z])(?=.*[\W]).*$"
                    ControlToValidate="txtPassword" >
                </asp:RegularExpressionValidator>
            </p>
            <p>
				Confirm Password:
                <asp:TextBox ID="txtConfirmPassword" runat="server" TextMode="Password"></asp:TextBox>
                <asp:RequiredFieldValidator ID="ConfirmPasswordRequired" runat="server" ControlToValidate="txtConfirmPassword"
                    ErrorMessage="*Confirm Password is required."
                    Enabled="false" ValidationGroup="ValidationGroup1"></asp:RequiredFieldValidator>
                <asp:CompareValidator ID="NewPasswordCompare" runat="server" ControlToCompare="txtPassword"
                    ControlToValidate="txtConfirmPassword"  ErrorMessage="*Confirm Password must match with the Password."
                    ValidationGroup="ValidationGroup1"></asp:CompareValidator>
            </p>
            <p>
                <asp:Button ID="Button1" runat="server" Text="Save" ValidationGroup="ValidationGroup1"
                    OnClick="Button1_Click" OnClientClick="Validate();" />
            </p>

于 2015-06-06T06:22:24.660 回答
0

这是一个想法,我也最终使用了这个解决方案:

如何设置比较验证器以验证密码文本框并将其与确认进行比较。这样,比较验证器只有在密码文本框中有值时才会触发。

<div class="control-group">
    <label class="control-label" for="PositionName">Password:</label>
    <div class="controls">
        <asp:TextBox ID="txtPassword" runat="server" TextMode="Password"/>      
    </div>
</div>
<div class="control-group">
    <label class="control-label" for="PositionName">Confirm Password:</label>
    <div class="controls">
        <asp:TextBox ID="txtConfirmPassword" runat="server" TextMode="Password"/>       
        <asp:CompareValidator ID="compPassword" runat="server" ControlToValidate="txtPassword"
                      ControlToCompare="txtConfirmPassword" ErrorMessage="Password Mismatch" SetFocusOnError="True"
                      ValidationGroup="1" CssClass="error"/>
    </div>
</div>
于 2016-12-21T09:22:48.433 回答