今天沒事就搞了一個asp的ajax留言板,這段時間學php了,很久沒搞asp了,今天溫習溫習一下.下面我們來簡單的介紹一下,留言板的設計思路,由於很簡單,我們主要的是在ajax傳回值上與儲存資料上,所以對asp就不多說了,
下面來看看所用到的檔案.
addajax.asp
<%
Dim conn,rs
Dim connstr
Dim sqlCmd
'建立資料庫連接對象並開啟
set conn=server.createobject("adodb.connection")
connstr="Provider=Microsoft.jet.oledb.4.0;data source=" & server.mappath("GuestBook.mdb")
conn.open connstr
'用於從資料庫中擷取資料的sql語句
sqlCmd="select title,author,date,content from data order by date desc"
'建立資料集對象
set rs=server.createobject("adodb.recordset")
'從資料庫中擷取資料
rs.open sqlCmd,conn,1,1
%>
由於比較懶所以就把串連或ajax都寫在一個頁面了.如果需要用的朋友可以下載下去自己修改即可.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title>Ajax GuestBook</title>
<style type="text/css">
<!--
body { font-size:0.75em;text-align:center;}
dl { margin:0;}
dt { background-color:#666;color:#fff;margin:1px;padding:0 3px;}
dd { margin:3px;}
div { margin:auto;line-height:150%;text-align:left;width:400px;border:1px solid #666;}
#postBox { margin-top:10px;}
dd.button { text-align:center;}
dd.button input { margin:0 20px;}
//-->
</style>
<script type="text/javascript">
<!--
//將使用者輸入非同步提交到伺服器
function ajaxSubmit(){
//擷取使用者輸入
var title=document.forms[0].title.value;
var author=document.forms[0].author.value;
var content=document.forms[0].content.value;
//建立XMLHttpRequest對象
var xmlhttp;
try{
xmlhttp=new XMLHttpRequest();
}catch(e){
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
//建立請求結果處理常式
xmlhttp.onreadystatechange=function(){
if (4==xmlhttp.readyState){
if (200==xmlhttp.status){
var date=xmlhttp.responseText;
addToList(date);
}else{
alert("error");
}
}
}
//開啟串連,true表示非同步提交
xmlhttp.open("post", "ajaxAdd.asp", true);
//當方法為post時需要如下設定http頭
xmlhttp.setRequestHeader('Content-type','application/x-www-form-urlencoded');
//發送資料
xmlhttp.send("title="+escape(title)+"&author="+escape(author)+"&content="+escape(content));
}
//將使用者輸入顯示到頁面
function addToList(date){
//擷取留言列表div容器
var msg=document.getElementById("msgList");
//建立dl標記及其子標記
var dl=document.createElement("dl");
var dt=document.createElement("dt");
var dd=document.createElement("dd");
var dd2=document.createElement("dd");
//將結點插入到相應的位置
msg.insertBefore(dl,msg.firstChild);
dl.appendChild(dt);
dl.appendChild(dd);
dl.appendChild(dd2);
//填充留言內容
dt.innerHTML="標題:"+document.forms[0].title.value;
dd.innerHTML="作者:"+document.forms[0].author.value+" 日期:"+date;
dd2.innerHTML=document.forms[0].content.value;
//清空使用者輸入框
document.forms[0].title.value="";
document.forms[0].author.value="";
document.forms[0].content.value="";
}
//-->
</script>
</head>
<body>
<div id="msgList">
<%
'遍曆記錄集產生Html代碼,從而將資料顯示於頁面
while not rs.eof
%>
<dl>
<dt>標題:<%=rs("title")%></dt>
<dd>作者:<%=rs("author")%> 日期:<%=rs("date")%></dd>
<dd><%=rs("content")%></dd>
</dl>
<%
rs.movenext
wend
'關閉資料庫連接及記錄集,釋放資源
rs.close
conn.close
set rs=nothing
set conn=nothing
%>
</div>
<div id="postBox">
<form name="theForm" method="post">
<dl>
<dt>發表您的留言</dt>
<dd>標題:<input type="text" maxlength="150" size="45" name="title"/></dd>
<dd>作者:<input type="text" maxlength="50" size="45" name="author"/></dd>
<dd>內容:<textarea rows="10" cols="45" name="content"></textarea></dd>
<dd class="button">
<input type="button" onclick="ajaxSubmit()" value="提交"/>
<input type="reset" value="重填"/>
</dd>
</dl>
</form>
</div>
</body>
</html>
後面繼續.