campos de senha não limpar em enviar em asp.net mvc
-
03-07-2019 - |
Pergunta
Eu tenho uma página de preferências do usuário no qual o usuário pode digitar a sua senha atual, nova senha e confirme a nova senha. Quando o usuário envia o formulário envia-los para uma ação. O problema é que quando os submete o formulário, os campos de senha fique cheio. Eu quero que eles para limpar. Tentei javascript mas quando eu uso document.preferences.submit (), a enviar não é acionado, ou a ação não é acionado, ou ambos. Aqui está o código:
<script language="JavaScript" type="text/javascript">
function clearpwd() {
document.preferences.submit();
document.preferences.currentPassword.value = '';
document.preferences.newPassword.value = '';
document.preferences.confirmPassword.value = '';
}
</script>
<% using (Html.BeginForm("ChangePreferences", "Home", FormMethod.Post, new { id="preferences", name="preferences" })) { %>
<div>
<div style="text-align:left; width:500px;">
<div class="FormLabel">User Information:</div>
<table border="0" cellpadding="4" cellspacing="0">
<tr>
<td>First Name:</td>
<td>
<%= Html.TextBox("firstName")%>
<%= Html.ValidationMessage("FirstName") %>
</td>
</tr>
<tr>
<td>Last Name:</td>
<td>
<%= Html.TextBox("lastName") %>
<%= Html.ValidationMessage("LastName") %>
</td>
</tr>
<tr>
<td>New email:</td>
<td>
<%= Html.TextBox("email")%>
<%= Html.ValidationMessage("Email") %>
</td>
</tr>
<tr>
<td>Billing Method:</td>
<td>
<%=Html.RadioButton("billingMethod", 'E', new { id = "BillingMethod_E", value = 'E' })%><label for="BillingMethod_E">Electronic</label>
<%=Html.RadioButton("billingMethod", 'M', new { id = "BillingMethod_M", value = 'M' })%><label for="BillingMethod_M">Mailing</label>
</td>
</tr>
</table>
</div>
<br /><br />
<div style="text-align:left; width:500px;">
<div class="FormLabel">Login and Security Information:</div>
<table border="0" cellpadding="4" cellspacing="0">
<tr>
<td>Current Password</td>
<td>
<%= Html.Password("currentPassword") %>
<%= Html.ValidationMessage("currentPassword") %>
</td>
</tr>
<tr>
<td>New password:</td>
<td>
<%= Html.Password("newPassword") %>
<%= Html.ValidationMessage("newPassword") %>
</td>
</tr>
<tr>
<td>Confirm new password:</td>
<td>
<%= Html.Password("confirmPassword") %>
<%= Html.ValidationMessage("confirmPassword") %>
</td>
</tr>
<tr>
<td>Security Question:</td>
<td>
<%= Html.TextBox("securityQuestion") %>
<%= Html.ValidationMessage("SecurityQuestion") %>
</td>
</tr>
<tr>
<td>Security Answer:</td>
<td>
<%= Html.Password("securityAnswer") %>
<%= Html.ValidationMessage("SecurityAnswer") %>
</td>
</tr>
</table>
</div>
<br /><br />
<table>
<tr>
<td></td>
<td><input type="submit" value="Change Preferences" onclick="clearpwd()" /></td>
</tr>
</table>
</div>
<% } %>
Solução
- Para depurar problemas JavaScript, melhor postar o HTML gerado
- Para depurar problemas de JavaScript mais fácil, usar o navegador Firefox com Firebug extensão.
Edit: Você está tentando limpar a senha, após a página é enviada. Depois página de apresentação navega para outra página, então eu acho que, JavaScript não afetará quaisquer elementos DOM depois disso.
Você pode tentar a seguinte sequência.
- Loja usuário e senha em variáveis ??JavaScript.
- claros os valores username e senha.
- Post para a página com os valores armazenados.
Outras dicas
Poderia ser enchimento seu navegador no campo de senha se você tem que definir a lembrar sua senha (s). Eu tive isso acontecer para mim.