xajax的FORM例子
更新時(shí)間:2006年11月25日 00:00:00 作者:
復(fù)制代碼 代碼如下:
<?php
// signup.php
// demonstrates a simple multipage form using xajax
// and the xajax.getFormValues() function.
// using xajax version 0.1 beta4
// http://xajax.sourceforge.net
session_start();
include ("xajax.inc.php");
function processForm($aFormValues)
{
if (array_key_exists("username",$aFormValues))
{
return processAccountData($aFormValues);
}
else if (array_key_exists("firstName",$aFormValues))
{
return processPersonalData($aFormValues);
}
}
function processAccountData($aFormValues)
{
$objResponse = new xajaxResponse();
$bError = false;
if (trim($aFormValues['username']) == "")
{
$objResponse->addAlert("Please enter a username.");
$bError = true;
}
if (trim($aFormValues['newPass1']) == "")
{
$objResponse->addAlert("You may not have a blank password.");
$bError = true;
}
if ($aFormValues['newPass1'] != $aFormValues['newPass2'])
{
$objResponse->addAlert("Passwords do not match. Try again.");
$bError = true;
}
if (!$bError)
{
$_SESSION = array();
$_SESSION['newaccount']['username'] = trim($aFormValues['username']);
$_SESSION['newaccount']['password'] = trim($aFormValues['newPass1']);
$sForm = "<form id=\"signupForm\" action=\"javascript:void(null);\" onsubmit=\"submitSignup();\">";
$sForm .="<div>First Name:</div><div><input type=\"text\" name=\"firstName\" /></div>";
$sForm .="<div>Last Name:</div><div><input type=\"text\" name=\"lastName\" /></div>";
$sForm .="<div>Email:</div><div><input type=\"text\" name=\"email\" /></div>";
$sForm .="<div class=\"submitDiv\"><input id=\"submitButton\" type=\"submit\" value=\"done\"/></div>";
$sForm .="</form>";
$objResponse->addAssign("formDiv","innerHTML",$sForm);
$objResponse->addAssign("formWrapper","style.backgroundColor", "rgb(67,149,97)");
$objResponse->addAssign("outputDiv","innerHTML","\$_SESSION:<pre>".var_export($_SESSION,true)."</pre>");
}
else
{
$objResponse->addAssign("submitButton","value","continue ->");
$objResponse->addAssign("submitButton","disabled",false);
}
return $objResponse->getXML();
}
function processPersonalData($aFormValues)
{
$objResponse = new xajaxResponse();
$bError = false;
if (trim($aFormValues['firstName']) == "")
{
$objResponse->addAlert("Please enter your first name.");
$bError = true;
}
if (trim($aFormValues['lastName']) == "")
{
$objResponse->addAlert("Please enter your last name.");
$bError = true;
}
if (!eregi("^[a-zA-Z0-9]+[_a-zA-Z0-9-]*(\.[_a-z0-9-]+)*@[a-z??????0-9]+(-[a-z??????0-9]+)*(\.[a-z??????0-9-]+)*(\.[a-z]{2,4})$", $aFormValues['email']))
{
$objResponse->addAlert("Please enter a valid email address.");
$bError = true;
}
if (!$bError)
{
$_SESSION['newaccount']['firstname'] = $aFormValues['firstName'];
$_SESSION['newaccount']['lastname'] = $aFormValues['lastName'];
$_SESSION['newaccount']['email'] = $aFormValues['email'];
$objResponse->addAssign("formDiv","style.textAlign","center");
$sForm = "Account created.<br />Thank you.";
$objResponse->addAssign("formDiv","innerHTML",$sForm);
$objResponse->addAssign("formWrapper","style.backgroundColor", "rgb(67,97,149)");
$objResponse->addAssign("outputDiv","innerHTML","\$_SESSION:<pre>".var_export($_SESSION,true)."</pre>");
}
else
{
$objResponse->addAssign("submitButton","value","done");
$objResponse->addAssign("submitButton","disabled",false);
}
return $objResponse->getXML();
}
$xajax = new xajax();
//$xajax->debugOn();
$xajax->registerFunction("processForm");
$xajax->processRequests();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<?php $xajax->printJavascript(); ?>
<style type="text/css">
#formWrapper{
color: rgb(255,255,255);
background-color: rgb(149,67,97);
width: 200px;
}
#title{
text-align: center;
background-color: rgb(0,0,0);
}
#formDiv{
padding: 25px;
}
.submitDiv{
margin-top: 10px;
text-align: center;
}
</style>
<script type="text/javascript">
function submitSignup()
{
xajax.$('submitButton').disabled=true;
xajax.$('submitButton').value="please wait...";
xajax_processForm(xajax.getFormValues("signupForm"));
return false;
}
</script>
</head>
<body>
<div id="formWrapper">
<div id="title">Create a New Account</div>
<div id="formDiv">
<form id="signupForm" action="javascript:void(null);" onsubmit="submitSignup();">
<div>Username:</div><div><input type="text" name="username" /></div>
<div>Password:</div><div><input type="password" name="newPass1" /></div>
<div>Confirm Password:</div><div><input type="password" name="newPass2" /></div>
<div class="submitDiv"><input id="submitButton" type="submit" value="continue ->"/></div>
</form>
</div>
</div>
<div id="outputDiv">
</div>
</body>
</html>
相關(guān)文章
使用ajax和history.pushState無刷新改變頁面URL示例
這篇文章主要介紹了使用ajax和history.pushState無刷新改變頁面URL示例,需要的朋友可以參考下2014-10-10
ajax回調(diào)函數(shù)參數(shù)傳遞正確方法
ajax回調(diào)函數(shù)參數(shù)傳遞正確方法,很多朋友習(xí)慣的寫錯(cuò)了,這里簡單的小結(jié)下。2010-12-12
關(guān)于多個(gè)Ajax請求執(zhí)行返回先后的問題示例探討
這篇文章主要與大家探討下關(guān)于多個(gè)Ajax請求執(zhí)行返回先后的問題,需要的朋友可以參考下2014-07-07
PHP Ajax實(shí)現(xiàn)頁面無刷新發(fā)表評論
PHP Ajax實(shí)現(xiàn)頁面無刷新發(fā)表評論...2006-12-12
kkpager 實(shí)現(xiàn)ajax分頁查詢功能
kkpager 實(shí)現(xiàn)ajax分頁查詢功能,前臺(tái)分頁數(shù)據(jù),適合數(shù)據(jù)少量的時(shí)候,因?yàn)榉猪摰臄?shù)據(jù)是從后臺(tái)獲取的,大數(shù)據(jù)的話不建議使用 ,具體前后臺(tái)代碼大家參考下本文吧2017-08-08
json獲取數(shù)據(jù)庫的信息在前端頁面顯示方法
今天小編就為大家分享一篇json獲取數(shù)據(jù)庫的信息在前端頁面顯示方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
Ajax異步請求的五個(gè)步驟及實(shí)戰(zhàn)案例
通過在后臺(tái)與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,Ajax可以使網(wǎng)頁實(shí)現(xiàn)異步更新,下面這篇文章主要給大家介紹了關(guān)于Ajax異步請求的五個(gè)步驟及實(shí)戰(zhàn)案例的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
使用ajax技術(shù)無刷新動(dòng)態(tài)調(diào)用新浪股票實(shí)時(shí)數(shù)據(jù)
由于最近網(wǎng)速慢的緣故,查看股票信息時(shí)網(wǎng)頁老是打不開。這幾天一直在研究ajax,于是用jquery自己做了一個(gè)自動(dòng)讀取新浪股票實(shí)時(shí)數(shù)據(jù)的頁面2014-08-08
用ajax xml的數(shù)據(jù)讀取的HelloWorld程序
我們經(jīng)常會(huì)使用JavaScript實(shí)現(xiàn)動(dòng)態(tài)的改變div里面的內(nèi)容,尤其是使用ajax的時(shí)候,尤為重要。2009-04-04

