J'ai un formulaire avec le code HTML ci-dessous:formulaire ne présente pas lors de l'exécution de la fonction submit() jQuery
<form id="course_edit_form" name="course_form" action="/courses/save" method="post">
<fieldset>
<div id="side-left">
<!-- Course Name -->
<input type="hidden" id="course_id" name="course_id" value="${c.the_course.id}" />
<div>
<label for="name" id="name_label">Course name<em>*</em></label>
${h.tags.text("name", c.the_course.name, size=40)}
</div>
<!-- Event Type -->
<div>
<label for="type_list" id="class_type_label">Event type</label>
<p>Use Ctrl to do multi-select</p>
<select multiple="multiple" id="type_list" class="type-box required" name="type_list">
% for ty in c.all_types:
% if int(ty.id) in c.typeids:
<option selected="selected" value="${int(ty.id)}">${str(ty.name)}</option>
% else:
<option value="${int(ty.id)}">${str(ty.name)}</option>
% endif
% endfor
<option value="all">All</option>
</select>
</div>
<div>....more input fields here</div>
</div>
<!-- Controls -->
<div class="controls">
<input id="delete" name="delete" type="button" value="Delete" />
<input id="submit" name="submit" type="submit" value="Update" />
</div>
</fieldset>
</form>
Je joint un gestionnaire de clic à mon bouton soumettre pour que mon javascript d'abord valider mon formulaire avant soumettre le formulaire actuel. Si tout se passe bien pendant la validation, je vais mettre un drapeau "course_form_valid" à true. Dans les dernières lignes de mon couple de javascript je:
if (course_form_valid) {
jQuery('#course_edit_form').submit();
}
Cependant, la ligne ci-dessus présente jamais la forme même lorsque course_form_valid est vrai. J'ai même essayé de supprimer les attributs d'action et la méthode de ma forme et a utilisé le javascript ci-dessous à la place, mais cela ne fonctionnerait pas:
if (course_form_valid) {
jQuery('#course_edit_form').submit(function() {
jQuery.ajax({
url: '/courses/save',
type: 'GET',
data: jQuery('#course_edit_form').serialize(),
async: false
});
});
}
Que se passe-t-il? Quelqu'un peut-il m'aider s'il vous plaît?
-Mark
pourriez-vous s'il vous plaît ajouter un exemple de travail jsbin? www.jsbin.com –
Oh désolé j'ai oublié de mentionner que la première ligne de ma fonction de gestionnaire de clic a e.preventDefault(); Est-ce que cela cause quelques problèmes? – Mark
Je n'arrive pas à trouver le problème, tous les autres codes js s'il vous plait ... comment 'course_form_valid' est défini sur' true'? avez-vous essayé 'jQuery ('# course_edit_form'). submit();' sans le 'if'? – Reigel