EXTJS和javaweb应用的开发思路
近期。做些几个基于extjs界面的应用。在此。总结一下要点。标题是基于javaweb,可是基本上各种server端语言都适用。使用Extjs做界面,无非就是取消了原来非常多的jsp文件,转而使用Extjs来訪问,但有些地方多少有些不方便,下面是我自己遇到的问题和经验。
1.多少个jsp合适呢?没有特殊要求的话,2个就能够,一个是login,一个是系统主页。登录页一般须要比較花哨。单独做一页。比較easy套用样式;主页则包括基本的布局。功能,而功能靠extjs来实现。对于一些特殊的页面。比方须要特定html头(doctype/指定特定的ie版本号等)的页面/activex控件,仅仅能单独用一个页面去搞,在Extjs中能够使用Panel里面的html属性指定一个iframe来载入此页面。
2.获得登录用户相关的信息或者server端信息(如当前日期,js里的时间非常多时候须要真正的当前日期,而不是client上的时间。不靠谱啊)。这个我使用server端程序生成一个mime类型为text/javascript的page。能够是servlet/action之类的东西,然后再首页上当作js文件来引用。
这样就不须要用ajax去server取,效率较高其执行稳定。假设这有的信息须要更新。比方用户改动了自己的真实姓名,能够又一次载入这个server端的js。我用了jquery的$.getScript方式来更新。也就是用户改动自己的信息成功后,调用$.getScript('userdata.action',callback)这样的方式。
3.登录超时的推断。
这里须要2种推断:1是用户刷新主页面,这就用普通的Filter来推断,超时了就跳回登录页;2时ajax请求的时候推断超时。当然也是用filter。可是用js构建界面无法响应filter中进行的跳转,须要加点处理。让js能够获得超时的信息,并用js进行跳转。
比方没有超时,给httpHeader添加个sessionstatus=pass这种值,
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest)request;
Member currentMember = SysUtil.getCurrentMember(req);//获得当前登录用户
HttpServletResponse rep = ((HttpServletResponse)response);
if(currentMember != null){
rep.setHeader("sessionstatus", "pass");
chain.doFilter(request, response);
}}
<pre>
server端filter的代码可能是这样:
<p></p><p>在client,用Extjs的Ajax事件进行捕捉,比如:</p><p></p><pre code_snippet_id="480857" snippet_file_name="blog_20141008_2_738930" name="code" class="javascript">Ext.Ajax.on('requestcomplete',checkUserSessionStatus, this);
function checkUserSessionStatus(conn,response,options){
//alert("checkUserSessionStatus")
//Ext又一次封装了response对象
if(response.getResponseHeader){
var sessionstatus = response.getResponseHeader("sessionstatus");
if(sessionstatus != 'pass'){
alert("登录超时,又一次进入系统");
window.location = "login.jsp";
}
}
}
4.javascript闭包的使用。在普通页面里能够不用闭包。由于页面引用的js相对较少,无用的js文件能够不引用,要找个js文件中的内容相对easy。
而基于extjs或者其它js界面框架的程序,js文件肯定非常多,并且大部分都须要在系统主页上引用,这非常可能造成查找一个函数非常吃力的情况,也不利于编写清晰的代码。所以必须使用闭包来把各个功能里面的js函数区分开。比方能够用ProjectName.modelName这样的方式来分包,比方创建用户列表的函数位于UserInfo.js里面,此能够这样写:
var MyProject.UserInfo = {};//MyProject应该在主js文件里定义,如var MyProject = {};
MyProject.UserInfo.createUserList = function(){
//创建用户列表面板的代码。。
。
}
EXTJS和javaweb应用的开发思路的更多相关文章
- halcon学习笔记——机器视觉工程应用的开发思路【转】
转自:http://www.cnblogs.com/hanzhaoxin/archive/2013/02/15/2912879.html 机器视觉工程应用主要可划分为硬件和软件两大部分. 硬件:工程应 ...
- Android常见开发思路
开发思路 刷新: 重新获取数据 清空list 更新适配器 关闭进度条. 加载更多 1. 重新获取数据 添加list 更新适配器 添加轮播条. 自己设计轮播条View 引入lib库文件 设置轮播条数据. ...
- JavaWeb网站后台开发记录手册
1.javaweb网站后台开发 1.封装DBTools类 1.注册数据库驱动 Class.forName("oracle.jdbc.driver.OracleDriver"); 2 ...
- OpenWRT - WEB界面开发思路和基本方法
想要对OpenWRT的WEB界面(*下称界面)进行修改.修改的目标是: 1.修改页面的样式,设计为企业的风格(stylesheet) 2.新建自己的功能,实现 访问页面后,用户就可以对配置文件(也就是 ...
- 初次接触ARM开发,理清这四个开发思路很重要!
初次接触ARM开发,理清这四个开发思路很重要! 由于涉及编程,学习ARM单片机系统对于从事电子电路的设计者来说是有些困难的,学习知识不难,难的是理清其中的开发思路,找到一个好的起点.本文就将从这一步入 ...
- 微信小程序开发思路
小程序还没有完全开放,不能真实体验,但通过文档和开发工具,可以了解到他的开发思路 下面就介绍下小程序的开发方式,希望能帮助有兴趣的朋友对整体思路有个快速了解 整体结构 默认示例项目的目录结构 从后缀名 ...
- Halcon学习笔记——机器视觉应用工程开发思路及相机标定
机器视觉应用工程开发思路 机器视觉应用工程主要可划分为两大部分,硬件部分和软件部分. 1.硬件部分,硬件的选型至关重要,决定了后续工作是否可以正常开展,其中关键硬件部分包括:光源,相机以及镜头. 2. ...
- 微信小程序红包开发思路 微信红包小程序开发思路讲解
之前公司开发小程序红包,将自己在开发的过程中遇到的一些坑分享到了博客里.不少人看了以后,还是不明白怎么开发.也加了我微信咨询.所以今天,我就特意再写一篇文章,这次就不谈我开发中遇到的坑了.就主要给大家 ...
- halcon机器视觉工程开发思路
参考:halcon学习笔记——机器视觉工程应用的开发思路https://www.cnblogs.com/hanzhaoxin/archive/2013/02/15/2912879.html
随机推荐
- Android车载导航的一些困境
车载导航从最初的用解码芯片,过渡到用WinCE系统,已经形成了一个较大的产业.车载导航使用上的一些大原则,基本上被固定了下来.如今WinCE走到了尽头,Android车载导航開始发力,但由于Andro ...
- C Tricks(十九)—— 求以任意数为底的对数
本文仅求对数的整数部分: int log(int n, int base){ int i = 1, cnt = 0; while (i*base < n){ i *= base; ++cnt; ...
- !!在JS中代表什么
!!一般用来将后面的表达式转换为布尔型的数据(boolean), javascript约定和c类似,规则为 ·false.undefinded.null.0."" 为 false, ...
- POJ 3264 Balanced Lineup 线段树RMQ
http://poj.org/problem?id=3264 题目大意: 给定N个数,还有Q个询问,求每个询问中给定的区间[a,b]中最大值和最小值之差. 思路: 依旧是线段树水题~ #include ...
- java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: student is not mapped
Spring 5.0 +Jpa,使用@Query实现 自定义查询报错: java.lang.IllegalArgumentException: org.hibernate.hql.internal.a ...
- 9.5 Binder系统_驱动情景分析_transaction_stack机制
参考文章:http://www.cnblogs.com/samchen2009/p/3316001.html test_server服务进程可能有多个线程,而在发送数据的时候handle只表示了那个进 ...
- 9.3 Binder系统_驱动情景分析_服务获取过程
4. 服务获取过程 test_client客户端: (1)在用户态先构造name=“hello”的数据(服务的名字是hello),调用ioctl发送数据给service_manager(handle= ...
- Android 利用an框架快速实现夜间模式的两种套路
作者:Bgwan链接:https://zhuanlan.zhihu.com/p/22520818来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 网上看到过大多实现夜间模 ...
- PHP解决约瑟夫环问题
PHP解决约瑟夫环问题 一.总结 二.PHP解决约瑟夫环问题 约瑟夫环(约瑟夫问题)是一个数学的应用问题:已知n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围.从编号为k的人开始报数,数到 ...
- 嵌入式arm linux环境中gdb+gdbserver调试
一.前言嵌入式Linux系统中,应用开发过程中,很多情况下,用户需要对一个应用程序进行反复调试,特别是复杂的程序.采用GDB方法调试,由于嵌入式系统资源有限性,一般不能直接在目标系统上进行调试,通常采 ...