浏览 2636 次
锁定老帖子 主题:怎样使用Ajax 简化我们的分层设计
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2007-08-07
正常情况下,我们的系统 分为 entity dataaccess business ui 四层,这个我就不罗嗦了. 考虑如下常见情况(举个最简单的例子) 比如有两张表: User, Experience. Experience 有一个外键,指向User 考虑没有Ajax的情况,要实现这样一个简单的页面:某个User的详细信息页面,页面需要同时列出 User信息,及这个User的 Experience信息。 正常情况,我们实现此页面的逻辑为: 数据库存储过程级别: 使用 表之间的 Join 方式,输出 User + Experience 的复合信息。 Entity Layer:将数据库返回来的数据,分解,分别映射到 某个 User 及 Experience 集合。 Business Layer : 组合两种类型的 Object 返回给页面 UI Layer: 页面读取数据... 说明:我写的这是比较通用的方式,自然有很多其他实现方式,但是,不管怎样,必然会涉及 同样一次操作涉及多种对象,导致 服务器端 要花很多时间处理 这些对象之间的关系。如上的例子,只涉及到 2 张表,1 个级别的关联,如果实际情况 超过 2 张表,超过 1 个级别呢?... 合理应用 Ajax,我们可以完全避免此类情况的出现,任何原子性的操作,只涉及到一种对象 还是对上面的例子:某个User的详细信息页面,页面需要同时列出 User信息,及这个User的 Experience信息。 应用Ajax我们可以怎么做呢? 首先直接输出 User 的详细信息,页面获取 User 的id 之后,再 Ajax 请求 其 Experience 信息。 这个过程,相信大家对比一下,很轻松就可以发现如下几个优点: 1. 整个过程 不需要浪费 服务器资源处理对象之间的关系 2. 每次请求,只涉及一个类型的对象 3. 无论涉及多少张表,及 多少张表之间的关联,通过这种方式,均特别容易实现 4. 任何 layer 的设计,只需要正对一种对象 的 (增,删,改,查...)。 5........ 最近写了三个站点,按时间先后: 1. 自己的站点:http://www.city366.com/ 纯 Ajax 网站,整个网站只有一个页面(site map 除外,那不是给人用的,是为SEO做的).如果你打开source code,可以发现,几乎没有任何 html 代码,全部通过js创建 html objects. 2. 公司的项目:http://www.backofmyhand.com/ ,也是纯 Ajax 功能站点。 写了很多控件 scroll bar , 100行js代码+ css 实现的一棵 tree...,四个级别的缓存 DB-->XML-->Cache-->Client ...... 3. 自己的站点(还没做完): http://inn.city366.com/本来是打算借这个项目 尝试 SAAS 的,推广了一段时间后发现,国内的用户 至少5年后才会 认识SAAS,使用SAAS不知道要到 猴年马月,尝试基本宣告失败。 站点3,也写了自己写了个日历,尝试了很多新的东西,另外 http://inn.city366.com/housedetail.aspx?houseid=1 这个页面,实现了如上的事例 (先显示房子信息,然后 Ajax 调用订单,反映在右侧的日历上) 谢天谢地,不知不觉也罗嗦了一大堆... 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2007-08-08
http://www.city366.com/ 这个站点不错,但是功能上是不是太追求ajax了,我觉得有些超链接还是不用ajax技术好。
|
|
返回顶楼 | |
发表时间:2007-08-08
如果业务比较复杂的话,这种单映射作用也不是很大。比如要在服务器端做逻辑,做验证,还是一样要把数据从数据库里面取出来。
|
|
返回顶楼 | |