Eché un vistazo a los comentarios de Serhiy en la publicación de Sasha. El ejemplo jsFiddle Serhiy siempre era interesante, y yo quería escribir una respuesta que describe el comportamiento que Serhiy mencionó:
Digamos que usted tiene un formulario denominado myForm
:
var form = document.getElementById('myForm');
Para la captura de presentación cuando se utiliza un submit botón (< input type = 'submit' >):
try {
form.addEventListener("submit", validationFunction, false);
} catch(e) {
form.attachEvent("onsubmit", validationFunction); //Internet Explorer 8-
}
Nota: Si desea detener la forma de presentación, que hacen validationFunction
retorno falsa.
para enviar el formulario a través de JavaScript:
form.submit();
NOTA: Si utiliza un "botón" < input type = onclick = "form.submit()"/>, los controladores de eventos onsubmit añade a la No se llamará a attachEvent. Por lo tanto, debe usar algo como:
< tipo de entrada = "button" onclick = "if (validationfunction()) form.submit();"/>
o, alternativamente, si usted tiene un botón:
Puede agregar Javascript para insertarse en evento de clic del botón. var btnValidateAndSubmit = document.getElementById ("btnValidateAndSubmit");
try {
btnValidateAndSubmit .addEventListener("click", validationAndSubmitFunction, false);
} catch(e) {
btnValidateAndSubmit .attachEvent("onclick", validationAndSubmitFunction); //Internet Explorer 8-
}
Por último, digamos que usted está trabajando fuera de un formulario web de SharePoint para editar un elemento de la lista, y desea agregar una validación personalizada para el formulario web. Puede agregar el siguiente javascript al formulario web para agregar validación personalizada a onclick para los botones Aceptar.
var oElements = document.getElementsByTagName("input");
for (var i=0; i< oElements.length; i++)
{
var elementName = oElements[i].getAttribute("Title");
var elementType = oElements[i].getAttribute("type");
var elementValue = oElements[i].value;
if (elementType=="button" && elementValue=="OK")
{
var okbutton = oElements[i];
// alert("typeof okbutton.onclick = "+typeof okbutton.onclick);
if (typeof okbutton.onclick == "function")
{
var previousfunction = okbutton.onclick;
okbutton.onclick = function()
{
if (validateForm())
{
previousfunction();
}
};
}
else
{
var aspnetForm = document.getElementById("aspnetForm");
aspnetForm.attachEvent("onsubmit",validateForm);
okbutton.onclick = function()
{
if (validateForm())
{
aspnetForm.submit();
}
};
}
}
}
Esto no funciona. Me pregunto por qué esto se subevaporó? form.submit() no hace lo mismo que intenta ejecutar este código en http://jsfiddle.net/RgRwp/18/ – Serhiy
@Serhiy: ¿Alguna vez dijiste que sí? La pregunta era 'Una vez que he hecho mi validación, ¿cómo presento el formulario en javascript?' Creo que esto responde a esa pieza. –
Supongo que no. Y supongo que respondiste ambas preguntas correctamente. Es solo que no funcionan combinados entre sí. Eso me molestó un poco porque esta combinación ha perdido gran parte de mi tiempo en el pasado y odiaría que alguien vaya por ese agujero. Supongo que probablemente debería simplemente editar la respuesta en lugar de quejarme en los comentarios. – Serhiy