第19章Ajax聊天室_第1页
第19章Ajax聊天室_第2页
第19章Ajax聊天室_第3页
第19章Ajax聊天室_第4页
第19章Ajax聊天室_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第19章 Ajax 聊天室,在讲解ASP.NET Ajax Timer控件时,已经向读者讲解了使用组建开发的Ajax聊天室。在本章中将向读者展示一个使用JavaScript脚本开发无刷新聊天室。,19.1 需求分析和概要设计,本节将讲述聊天室的需求和一些实现中需要注意的细节,在聊天室的实现中要结合在进度条开发中学习到的定时局部刷新的方式进行开发。,19.1.1 需求分析,聊天室是在OA或CRM等商业Web系统中广泛提供的功能,对于聊天室而言,需要提供以下功能: 用户登录:只有当用户登录之后,用户才可以使用自定义昵称参与聊天。 管理员登录:管理员登录,可以进行清屏、删除用户等系统操作。 用户列表

2、的局部刷新:对于聊天室而言,用户会经常更换,需要动态加载用户列表,删除超时用户等。 聊天消息列表的局部刷新:聊天室内聊天记录是滚动变化的,需要随时更新聊天列表,使用户迅速获取聊天信息。 聊天列表信息及时删除,对于聊天列表这样的临时性存储器,需要随时删除过期信息,并添加新的信息。,19.1.2 概要设计,聊天室流程较为简单,本示例中未考虑用户注册等方式的聊天室,仅仅关注于实现聊天室主要功能的实现,流程如图所示:,19.2 实现代码,在本节中,展示了开发Ajax聊天室中的各种开发细节,以及如何使用定时刷新功能控制页面布局和内滚动条格式的控制。,19.2.1 聊天室后台引擎类,聊天引擎类是提供组装系

3、统消息,组装聊天信息列表、组装用户列表、动态刷新用户列表、动态刷新聊天信息列表的服务器端功能类,该类的实例被放置在Global文件中,被声明为Global类的公有静态变量。Global文件中声明聊天引擎类实例的代码如下所示: public static DataOperator.IChatEngine Engine=new ChatEngine(); ChatEngine类中的其他方法相对较为简单,就不一一进行讲解了,希望读者能够仔细阅读ChatEngine类的代码,学习如何创建高访问效率的服务器端支持。 在下一节中,将要讲解聊天程序中重要的组成部分-登录。,19.2.2 聊天登录页面,本示例

4、中,并未考虑用户注册功能,仅仅提供了用户登录功能,聊天登录页面的代码如下所示: 在后台代码中,首先在Page_Load事件中为TextBox添加在JavaScript事件处理函数,判断用户按下的键盘按键,如果是回车键即提交表单、页面回送。 在登录按钮的单击事件处理函数中,判断了用户是否已经存在,并对用户名的数据合法性进行了验证。,19.2.3 聊天页面前台代码,聊天页面的多数元素都是JavaScript脚本生成的, updateAll()函数是整个聊天页面无刷新实现最重要的方法。特别需要注意的是updateAll()函数中首先暂停执行定时调用,然后执行getUserList()函数异步请求服务

5、器获取用户列表,getUserList()函数在接收服务器响应后会调用getBufferText()方法异步请求服务器获取消息列表。 只有当getUserList()函数执行完毕,并获取了所有的用户列表及消息列表后,updateAll()函数才又一次调用setTimers()函数,实现定时页面局部刷新。通过在updateAll()函数中首先暂停定时局部刷新,然后请求服务器数据,再开启定时拒不刷新的方式,有效防止了定时局部刷新线程和请求服务器数据线程的并发冲突,防止了线程阻塞或死锁,可以极大的提高服务器与客户端的数据交互效率。,19.2.4 处理Ajax响应的服务器页面,实际上在本示例中,由于ChatEngine类封装了聊天室所有操作,所以Ajax响应服务器页面非常简单,仅仅根据请求参数决定返回的响应类型,代码如下所示: 处理Ajax请求的服务器页面仅仅封装了ChatEngine类中方法,并根据请求参数做出相应的处理,并将结果放入响应中返回至客户端。,19.3 小结,在本章中结合18章中介绍的定时局部刷新方式展现了Ajax聊天室的基本开发细节,并介绍了锁定机制在定时局部刷新方式中的重要性和优点,这些方式已经在大多数Ajax开发中得到了应用。读者需要仔细阅读本章示例,并模仿才能掌握这些方式。 在下一章中讲解WebQ

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论