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

本文介绍如何使用支持会话状态的Ajax技术简化Web应用开发,特别是对于文档管理系统中用户编辑文档时的锁定与通知功能。文章详细展示了服务器端函数及客户端JavaScript的实现方式。

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 onload="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、付费专栏及课程。

余额充值