`
sacred02
  • 浏览: 6956 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

opoa项目实践

阅读更多

One Page One Application单页面应用[OPOA或1P1A],也就是说,一个页面就是一个应用系统,整个系统只有一个页面,不再使用iframe, 页面提交不能再使用submit方式。

这样的好处是:很多东西,例如:JS,CSS,HEAD等整个系统都只需加载一次。加快响应速度。客户体验也有所提高,不再弹出窗口,不再整个页面进行刷新。

我们项目是使用dojo进行开发,使用ajax方式提交,当然也可以使用.do的方式提交,只不过返回的话,就是一个页面的信息,这个页面的信息放在一个div里,就像是粘贴过来的页面一样。由于dojo解释,加载时都是比较慢,整个项目如果全部使用dojo的组件,性能可能会有问题。现项目主要使用了dojo,tree, titlepane, layoutpane, contentpane, dialog等主要的组件,丢弃不需要的dojo组件。

项目实践过程中遇到的问题:

     1. 须保证页面元素ID唯一,全系统JS函数名唯一 [定义一个规范]

     2. 回调函数处理 [封闭Dojo提交的方式,增加回调处理]

     3. FORM提交 [使用dojo的form提交]

     4. JS加载问题 [使用与dojo组件绑定的方式加载,另一种方式,可以使用dojo的require方式进行加载]

     5. 附件上传问题 [使用dojo.io.iframe解决附件上传问题]

     6. 事务同步问题 [通过设置dojo提交参数,并且自己在回调进行特殊处理]

     ……

 

一点心得:

       在OPOA项目中,FORM—ID是一个非常重要的标志,很多元素都是通过FORM去找的。很多页面的交互也是通过FORM_ID去查找。一定要保证ID的唯一!!!

       由于使用DOJO,脚本的加载是一个比较大的问题,如果将所有脚本在进入系统时统一加载,这样网络传输的数据也会很大,系统性能有所影响!如果是按需加载,懒加载,可以提高进入系统的响应速度,但因为DOJO的限制,有些脚本不会生效,必须放在特殊的地方,例如:include进来的页面, JS脚本是不会执行的,必须放在包含页面的主页面上。这对于页面比较简单的应用来说,还是可以的,但如果页面交互比较复杂,业务逻辑比较复杂的话,JS将会非常之乱!后续维护工作压力也会比较大!经过一些实验,使用dojo,require机制进行动态加载脚本是一个不错的选择。

     例如:可以把一个业务模块的脚本全部放在一起, 使用require进行唯一加载!

if(!dojo._hasResource["holly.oss.SDH"]){
dojo._hasResource["holly.oss.SDH"] = true;
dojo.provide("holly.oss.SDH");


dojo.declare("holly.oss.SDH", null,
{
showSDHMsg: function() {
   showMsgDialog("haha", "成功了!", true);

});

}


      这是我们项目第一次使用OPOA思想,在大概一个月的摸索道路上,需要解决的问题是比较多的。而且前期开发的压力也是比较大!思想不同了,处理方式不同了,带来了更高的客户体验! 有得必有失,权衡中间的得失才是最重要的!我们正在成长,在OPOA的道路上!

       善于总结,我们就能提高,善于发现,我们就有机会!

分享到:
评论
2 楼 azllza 2008-06-27  
哈哈 买袭击 被我发现了啊
1 楼 chirs 2008-06-23  
One Page, One Application(后面缩写为OPOA,或者1P1A), 含义很简单:一个页面就是一个应用.而不是一个系统!

相关推荐

    mat-opoa:启动单页应用的mat插件

    mat-opoa Installation npm install --save-dev mat-opoa Usage var mat = require('mat'); var rap = require('mat-rap'); var opoa = require('mat-opoa'); // rap mock数据环境 mat.task('default', function () ...

    extjs得单页系统实例

    OPOAdemo.rar extjs得单页系统实例

    asp.net与extjs开发点卡在线销售系统

    整个系统都使用了AJAX(Asynchronous JavaScript and XML)技术,与服务器交互采用异步方式,真正实现了OPOA(One Page One Application)单页程序。减少了用户等待的时间,抛弃了传统的B/S那种,提交>等待>刷新。

    单页应用前端MVC框架Magix.zip

    OPOA(One Page One Application)应用。Magix 对 View 进行了父子结构抽象,通过 VOM(View Object Model)对象,管理带有父子关系的 View 的展示生命周期。Magix 特别注意避免单页应用的浏览器内存大量积累和内存...

    jquery.load 是无法替代 iframe的

    在IT行业中,jQuery是一个广泛使用的JavaScript库,它极大地...理解它们的区别,并根据项目需求选择合适的技术,是优化网页开发效率和用户体验的关键。同时,关注内存管理工具如sIEve,也是提高Web应用质量的重要一环。

    Javascript开发之js压缩篇.pdf

    作者引入了OPOA组件式开发方法,但是这种方法会增加js文件的总量。为了解决这个问题,作者推荐使用yui-compressor对js文件进行压缩混淆。 yui-compressor是Yahoo!开发的一款js压缩工具,可以将js文件压缩到原来的1/...

    网易企业邮箱5.0版创新功能全剖析.docx

    配合网易自主研发的第五代AJAX引擎、OPOA框架和自定义组件库,邮箱性能得到了显著提升,邮件到达速度加快,通信协议得到优化,页面加载速度提高35%。此外,智能动态组件系统确保了页面元素生成和显示的高效性,以及...

    5最值系列之阿氏圆问题.doc

    2. △OBP∽△OPA,即 OBOPOPOA=,变形为 2OPOA OB=×. 3. OPOBPAkOAOPPB===. 这些性质可以应用于解决各种问题,如确定圆心和半径、求解点的坐标等。 四、练习题和解答 我们提供了四个练习题和解答: 1. 已知 A...

    基于Ext的单页系统设计与研究.pdf

    这篇文章主要探讨了如何利用Ext框架设计和实现一个单页系统(One Page Application,OPOA),这是一种优化用户体验的Web应用模式,旨在提高响应速度和用户交互性。文章首先介绍了Ext和单页系统的概念。 **1. Ext...

    基于 HTML5 移动 Web App 开发.pdf

    例如,Android平台上的Web App方案会针对WebView组件进行优化和扩展,利用Webkit引擎提升性能,并通过界面优化技术如OPOA(Offscreen Page Cache)减少页面刷新,提升响应速度。 然而,HTML5技术目前仍存在成熟度...

    magix:Magix 旨在构建大规模、复杂的交互应用程序

    Magix npm install magix 简介 Magix适合用来构建大型的、交互复杂的应用。应用可以是前后端分离的单页...示例项目 magix-project 集成常见组件及开发中的功能,seajs+jquery magix-os web桌面系统 KISSY版本 点击这里

Global site tag (gtag.js) - Google Analytics