我有一种情况,我页面上的表单在每个表单提交一次后就会消失。例如,显示登录提示(使用Jquery Mobile)输入用户名和密码,对话框正常显示,输入被处理和验证,登录成功后显示主页。但是,如果我注销然后再次尝试重新登录,则只会显示页眉。输入字段和标签不存在。
我有另一个页面,其中有一个输入字段,在其中输入文本,进行 $.post 调用,返回 HTML 并使用 $('#results').html(dataReceived ) 函数调用。
显示结果时,表单似乎正在消失。这是页面文本:
<div data-role="page" id="Search" data-title="Search">
<div data-role="header" data-theme="e">
<h1>Search</h1>
</div>
<div data-role="content">
<form name="SearchForm" action="search.php">
SSN: <input type=number name="snum" size="9" value=""><br>
<input id="SearchButton" type="submit" value="Begin Search" data-inline="true">
</form>
<div id=SearchResults></div>
</div><!-- /content -->
</div><!-- /Search -->
我拦截表单的提交事件并在其他地方处理它。在 $.post AJAX 调用的回调函数中设置 div 内容的代码是:
$('#SearchResults').html(dataReceived);
一般信息:jquery 和 jquery mobile 的最新稳定版本。这是一个多页文件。不调用外部页面。一切都通过 $.post 调用完成。登录表单不会更新任何 HTML,它只是接收用户的 ID 并将其存储在一个变量中。
任何帮助,将不胜感激。谷歌在这方面不是我的朋友。
修改为显示表单提交代码:
$(document).ready(function() {
$('form').submit(function(event) {
event.preventDefault();
var thisForm=$(this);
var formUrl=thisForm.attr('action');
var formName=thisForm.attr('name');
var dataToSend=thisForm.serialize();
var callBack=function(dataReceived) {
thisForm.hide();
switch(formName) {
case 'loginForm':
if (dataReceived.length>0 && parseInt(dataReceived)>0) {
loggingIn=0;
userId=parseInt(dataReceived);
$.mobile.changePage("#home");
break;
}
thisForm.show();
break;
case 'SearchForm':
$('#SearchResults').html(dataReceived);
break;
}
};
dataToSend += '&seid=' + SESSID;
var rtnType="html";
switch(formName) {
case "loginForm":
rtnType="text";
break;
case 'SearchForm':
break;
}
$.post(formUrl,dataToSend,callBack,rtnType);
return false;
});