利用ajax.dll进行Ajax的开发4

SessionState

服务器端函数中很可能需要访问会话信息。为此,只需要通过传递给Ajax.AjaxMethod属性的一个参数告诉Ajax启用这种功能。

在考察包装器会话能力的同时,我们来看看其他几个特性。这个例子中我们有一个文档管理系统,用户编辑的时候会对文档加锁。其他用户可以请求在文档可用的时候得到通知。如果没有AJAX,我们就只能等待该用户再次返回来检查请求的文档是否可用。显然不够理想。使用支持会话状态的Ajax就非常简单了。

首先来编写服务器端函数,目标是循环遍历用户希望编辑的documentId(保存在会话中)并返回所有已释放的文档。

[Ajax.AjaxMethod(HttpSessionStateRequirement.Read)] public ArrayList DocumentReleased() {   if (HttpContext.Current.Session["DocumentsWaiting"] == null) {     return null;    }    ArrayList readyDocuments = new ArrayList();   int[] documents = (int[])HttpContext.Current.Session["DocumentsWaiting"];   for (int i = 0; i < documents.Length; ++i) {      Document document = Document.GetDocumentById(documents[i]);     if (document != null && document.Status == DocumentStatus.Ready) {        readyDocuments.Add(document);      }            }   return readyDocuments;    } } 要注意,我们指定了HttpSessionStateRequirement.Read值(还可以用WriteReadWrite)。

现在编写使用该方法的JavaScript

<script language="javascript"> function DocumentsReady_CallBack(response) {   if (response.error != null) {      alert(response.error);     return;    }   if (response.value != null && response.value.length > 0) {     var div = document.getElementById("status");      div.innerHTML = "The following documents are ready!<br />";     for (var i = 0; i < response.value.length; ++i) {        div.innerHTML += "<a href=/"edit.aspx?documentId=" + response.value[i].DocumentId + "/">" + response.value[i].Name + "</a><br />";      }          }    setTimeout('page.DocumentReleased(DocumentsReady_CallBack)', 10000); } </script>   <body οnlοad="setTimeout('Document.DocumentReleased(DocumentsReady_CallBack)', 10000);"> 结束语

AJAX技术已经催生了原来只有桌面开发才具备的健壮而丰富的Web界面。Ajax .NET包装器让您很容易就能利用这种新的强大技术。请注意,Ajax .NET包装器和文档仍在开发之中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值