我正在尝试通过jquery提交表单。我希望在jquery提交表单时让我的表单提交事件被触发。
但是当成功提交表单时,不会成功调用提交事件处理程序。
以下是代码:
<html>
<head>
<title>forms</title>
<script src="../common/jquery-1.6.2.min.js"></script>
<script>
$('#testform').submit(function() {
$.post($(this).attr("action"), $(this).serialize(), function(html) {
$("#menu").html('<object>'+html+'</object>');
});
return false; // prevent normal submit
});
</script>
</head>
<body>
<form id="testform" action="<%=getURL%>" method="post" >
<!-- <input type="hidden" value="DocQrySetup" name=form>
<input type="hidden" value="bdqdb1" name=config>-->
<input type="hidden" value="test" name=otherParams>
</form>
<script language=javascript>
$('#testform').submit();
</script>
<div id="menu" style="position:relative; bottom: 0; overflow:hidden;">
</div>
</body>
我搜索了所有论坛,但未能得到解决方案。
答案 0 :(得分:22)
当您运行第一个脚本时,表单不存在,因此您的事件处理程序无需附加任何内容。
要么将该处理程序移动到表单之后,要么将其包装在
中$(document).ready(function() {
$('#testform').submit(function() {
/* your code */
});
});
答案 1 :(得分:8)
当您附加事件侦听器时,未定义表单,在表单之后移动附加事件侦听器的代码或使用以下代码包装代码:
jQuery(document).ready(function ($) {
...
});
并添加提交按钮。
...
<input type="submit" value="submit">
...