cl991036
管理员
管理员
  • 注册日期2003-07-25
  • 发帖数5913
  • QQ14265545
  • 铜币29657枚
  • 威望213点
  • 贡献值0点
  • 银元0个
  • GIS帝国居民
  • GIS帝国铁杆
阅读:1355回复:1

静态页中利用AJAX.NET实现无刷新页面

楼主#
更多 发布于:2008-06-11 22:54
<DIV class=postBody>
<P>一、 导言 </P>
<P>  我们知道,ASP.net应用程序事实是在服务器上运行的,用户的请求要不断地送往远程的服务器,服务器执行完本地的程序后把重新装载页面再发送客户端。所以就出现了不断刷新的问题,页面不断闪烁。用户不厌其烦,运行效率也大大4降低,服务器的负荷加重。事实,客户端的请求在某一时刻只是通过向 Web 服务器提交新的请求来检索对用户输入所做的响应。这种情况下,开发人员可以使用 JavaScript 在客户端上加载所有响应,从而提供更好的用户体验。遗憾的是,在很多情况下,不必将所有响应都返回或加载到 JavaScript 要更好,只返回所要的结果,执行过程仍然在服务器上运行。AJAX 提供了一种新的中间选择,能够在维持及时响应和灵活性的同时利用基于服务器的应用程序。</P>
<P>  AJAX依靠服务器作为中介来分发和处理请求。为了完成这项工作,.net封装类依赖于客户端的请求对象,而xmlHttpRequest对象被大部分的浏览器支持,因此使用这个对象是一个不错的解决方案。</P>
<P>  因此,为了实现不刷新的页面,我们的客户端页面做成静态页面。静态页面通过Ajax.net调用.net类的方法。这是一种最简洁又高效的解决方案。</P>
<P>  二、 如何应用Ajax.net</P>
<P>  1.在工程中引入Ajax.dll文件。</P>
<P>  Ajax.dll是微软开发的应用在asp.net上的一个类库文件。该类库封装了XmlHttpRequest请求服务器的实现细节,是 Ajax知识应用在asp.net平台上的解决技术。在.net项目中,添加上对其的引用,然后就可以开始使用ajax.dll封装进行开发了。</P>
<P>  2.在web.config中设置HttpHandle</P>
<P>  为了使其可以工作,第一步必须做的是在web.config中安装设置封装包的HttpHandle,不去详细解释HttpHandle是如何工作的,我们只需要了解他们可以用来处理asp.net请求。例如,所有的目的为*.aspx的请求可以通过 System.Web.UI.PageHandlerFactory类发送到控制句柄,简单的说,我们把任何向ajax/*.ashx的请求发送到 Ajax.PageHandlerFactory的请求处理句柄。</P>
<P>  3.编写服务端函数</P>
<P>  现在我们编写服务器端函数,他们可以被客户端异步的调用。尽管现在还不能支持全部的返回类型,我们仍坚持服务器端添加功能。在codebehind文件的页面类里,添加下面的方法:</P>
<P>[Ajax.AjaxMethod()] <BR>public int ServerSideAdd(int firstNumber, int secondNumber) <BR>{ <BR> return firstNumber + secondNumber; <BR>}  </P>
<P><BR>  注意,这个函数有Ajax.AjaxMethod()定制属性,属性服务会告知ajax封装类为此方法创建一个javascript代理,这样才能被客户端调用。 </P>
<P>  三、 应用实例(点击下载源码)</P>
<P>  我们的应用程序主要是对数据库的操作,数据库的数据通过页面的表格呈现,页面完成增加、删除、更新、查询等功能。更主要的是它是一个通用的并且实现方法极为巧妙的例子。任何页面没有刷新现象并且代码十分精巧。下面的就通过Ajax技术实现这些功能。</P>
<P>  ·建立工程HttpForAjax,并在您的工程中引入Ajax.dll文件。</P>
<P>  ·在您的Web.config中加上。</P>
<P><httpHandlers> <BR><add verb="POST,GET" path="ajax/*.ashx" type="Ajax.PageHandlerFactory, Ajax"/> <BR></httpHandlers> <BR>   ·建立您的HTML页。</P>
<P>  1. 向工程里添加HTML页InfoClass.htm。该页面完成查询、常用工具及数据展现等功能。<BR>  页面主要放了四个DIV,一个是树" divTree "。一个是查询区叫"divFindTable"的,一个是工具栏叫<BR>"divToolbar"的,一个是数据区叫"divDataGrid"的。如下图:</P>

<P>  2. 在 <HEAD>与</HEAD>间加入一些引用如下:</P>
<P><script src=js/Xml.js></script> <BR><link href="css/myStyle.css" type="text/css" rel="stylesheet"> <BR><script src="/HttpForAjax/ajax/common.ashx" type="text/javascript"></script> <BR><script src="/HttpForAjax/ajax/Ttyu.AjaxData,HttpForAjax.ashx" type="text/javascript"></script>  </P>
<P><BR>  说明:Xml.js是用javascript写的一些客户端程序。</P>
<P>  myStyle.css为样式风格文件。 <BR>  common.ashx为调用Ajax的公用方法。 <BR>  HttpForAjax.ashx为下面我们要用Ajax编写的类的引用。其中HttpForAjax为工程的命名空间。 <BR>  Ttyu.AjaxData为自己开发的类,其中Ttyu为命名空间,AjaxData为类名。<BR> 3. 用javascript编写脚本方法,</P>
<P>function Init() <BR>{ <BR> DomTree=new dhtmlXTreeObject(document.getElementById('divTree'),"100%","100%",0); <BR> DomTree.setImagePath("imgs/"); <BR> DomTree.enableDragAndDrop(true) <BR> DomTree.setDragHandler(myDragHandler); <BR> DomTree.setOnClickHandler(SelectTreeNode); <BR> var s= AjaxData.GetXmlTree().value; <BR> DomTree.loadXMLString(s); <BR> DomTree.openItem("R_1"); <BR> SelectTreeNode("R_1"); <BR> divToolbar.innerHTML=AjaxData.GetToolBarTable(TableName).value; <BR> divDataGrid.innerHTML=GetTableOuterHTML(TableName);  <BR>} <BR> </P>
<P>  Init方法通过Ajax的GetXmlTree方法得到树的内容,GetToolBarTable取得工具栏的内容。通过GetTableOuterHTML方法取得物理表tInfoClass的所有数据并通过表格展现出来。</P>
<P>function Find() <BR>{ <BR> var Table=AjaxData.GetXmlFindTable("年级名称 like '%"+txtName.value +"%'"); <BR> divDataGrid.innerHTML=Table.value; <BR>} <BR> </P>
<P>  查询方法Find()是通过Ajax的GetXmlFindTable方法按年级名称查询并把结果展现出来。</P>
<P>function OpenAddWeb() <BR>{ <BR> var RetID =OpenAddWin('InfoClass_edit.aspx?IsAdd=true',370,300); <BR> if(RetID==-1) return; <BR> InsertRow(DataGrid1,RetID); <BR>}  <BR>  OpenAddWeb方法打开InfoClass_edit.aspx页在该页上完成增加数据的功能。如果返回值不为-1则表示有新数据增加的并把数据插入到表格的最后一行。RetID表示最后一行的ID. <BR>function OpenEditWeb(ThisCell) <BR>{ <BR> var ID=ThisCell.previousSibling.previousSibling.innerText;  <BR> var RetID =OpenAddWin("InfoClass_edit.aspx?ID="+ID+";IsAdd=false",370,300); <BR> if(RetID==-1) return; <BR> //有更新行 <BR> var CurrRow=ThisCell.parentElement <BR> SetRowText(CurrRow); <BR> // SetRowText(CurrRow,RetDataRow); <BR>} </P></DIV>
喜欢0 评分0
没钱又丑,农村户口。头可断,发型一定不能乱。 邮箱:gisempire@qq.com
mytest
论坛版主
论坛版主
  • 注册日期2006-12-17
  • 发帖数155
  • QQ
  • 铜币53枚
  • 威望0点
  • 贡献值0点
  • 银元0个
1楼#
发布于:2008-06-13 18:21
<img src="images/post/smile/dvbbs/em04.gif" /><img src="images/post/smile/dvbbs/em04.gif" />
举报 回复(0) 喜欢(0)     评分
游客

返回顶部