`
felixshao
  • 浏览: 1708 次
  • 性别: Icon_minigender_1
  • 来自: 广州
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

我们公司新的架构设计

 
阅读更多
我们公司最近更改的架构。新架构有如下特点:
1. 前台用Extjs。
  1.1 定义好baseLayout, 所有Screen都从它继承。分为Search Screen, toolBar, content Screen.
    Manu在Screen或ToolBar里面。
  1.2 封装好Ajax Call。
  1.3 使用ScriptLoad Manager动态Load js 文件。
  1.4 Base Screen 定义了 OnEnter, OnBeforeEnter,OnLeave, OnBeforeLeave Event,然后
每个Screen重写他们。
  1.5 BaseScreen 里面有几个重要的Function:
   1.5.1 把response 解析, 放到当前Screen的每个Section中的每个Field。每个Section有自己的Store,但
   Screen Render 时用一个主要的Loader, 只有Section单独Reload时才用Section自己的Loader。(避免Section与Section之间数据有依赖关系,如果一个Screen有多个Section而有时要Reload 2个以上Section,单独处理)
    1.5.2 CheckReadOnly,和 ApplyReadOnly
   1.5.3 ApplyPermission (response data 中包含 每一个field的permission(不显示,只读,无限制))
   1.5.4 流程控制(包含对OnEnter, OnBeforeEnter,OnLeave, OnBeforeLeave Event 的调用)。
   1.5.5 自定义Events的使用:Screen 初始化时加Events到Section,由Section fire Events 时调用Screen的Function。(好处: 同一个Section可以重用,放到不同的Screen中)
(未完)
分享到:
评论
23 楼 kimmking 2010-03-29  
感觉定下来的这些,其实是为了规范项目结构和约束开发。
22 楼 felixshao 2010-03-29  
mxdba321123 写道
ExtJs算是最“重”了吧,如果不是客户指定要用,那能不用就不用吧。类似的jquery完全可以代替,这个要看你们有没有比较好的前端人员了,傻瓜的同时意味的扩展性的降低。

还有那个validation,我不明白为什么要 单独弄出一个bean来,不能在真正的entity里,在需要验证的字段上加个annotation,然后在业务层,需要更新或者保存时用 反射 检验一下?

当然 如果使用了hibernate等 可以直接用他的validation


ExtJs提供的是一套前台的解决方案,例如GridPanel, selectionModel 等还允许任意override他的Class。
单独弄一个Bean出来而不能放在不能在真正的entity里是因为:

主要是方便,这个Bean不光是用来做Validation,接收request过来的数据,和返回Reponse时的数据都放里面了。再调用JsonObject 转换成Json String。跟Struts的FormBean是一样的。
21 楼 michaelyn 2010-03-29  
<div class="quote_title">qiren83 写道</div>
<div class="quote_div">同意楼上 至多用个JQUERY 不要EXTjs 傻瓜化的东西的另一面是约束性大 <br>拒绝YUI extjs </div>
<p> </p>
<p> 一个插件形式的东西,没看出exjs有什么约束,而且是基于js的,除非你用js觉得很约束。</p>
20 楼 michaelyn 2010-03-29  
<div class="quote_title">mxdba321123 写道</div>
<div class="quote_div">ExtJs算是最“重”了吧,如果不是客户指定要用,那能不用就不用吧。类似的jquery完全可以代替,这个要看你们有没有比较好的前端人员了,傻瓜的同时意味的扩展性的降低。 <br><br>还有那个validation,我不明白为什么要 单独弄出一个bean来,不能在真正的entity里,在需要验证的字段上加个annotation,然后在业务层,需要更新或者保存时用 反射 检验一下? <br><br>当然 如果使用了hibernate等 可以直接用他的validation</div>
<p> </p>
<p>你说用extjs扩展性低,我是不是可以理解成:用js开发扩展性低?</p>
<p>我觉得应该从另外一个角度看,extjs是从js扩展出来的东西</p>
19 楼 拥抱变化之美 2010-03-29  
大家看看这个网站,是用extjs写的:
www.chess.com
(我的账号:wienee,欢迎大家加我为好友,切磋一下)
18 楼 hommy8 2010-03-29  
基本的验证完全可以在前台做啊。除非你需要用到数据库
17 楼 hommy8 2010-03-29  
felixshao 写道
4. Validation 的处理:
  Validation是一个难点。页面上每一个Field都有可能要Validate,至少查空。第一步要把Field与Domain Model中的POJO 做映射。具体实现是:每一个页面的Screen Section对应一个Java ScreenBean,Field 与 ScreenBean的属性对应, annotate ScreenBean的属性(映射Domain Model中的POJO)。
举例:
页面某一个Section显示地址的一部分:
City Name, Street Name


要建立一个ScreenBean:

package com;

public class CityAndStreetBean {

@modelProperty("Address.city")
private String CityName;
@modelProperty("Address.street")
private String StreetName;


public void setCityName(String cityName) {
CityName = cityName;
}
public String getCityName() {
return CityName;
}
public void setStreetName(String streetName) {
StreetName = streetName;
}
public String getStreetName() {
return StreetName;
}
}



Domain Model 里面有POJO
Address 有 以下属性
city,street,和Country  

映射就建立起来了。建立映射的目的:
举例:
当用户在页面输入城市为:北京
而Domain Model中Address的Country为美国,可认为用户城市选择错误。

每个Service定义好想要Validate的内容,通过AOP配成before advice,因此必须Validation成功才能调用Service,否则返回提示信息给用户。


这个验证在后台做,个人不太赞同。首先你需要反射把用户的输入数据转换为bean,然后判断。这样增加了很多服务器无需的负担
16 楼 mxdba321123 2010-03-29  
ExtJs算是最“重”了吧,如果不是客户指定要用,那能不用就不用吧。类似的jquery完全可以代替,这个要看你们有没有比较好的前端人员了,傻瓜的同时意味的扩展性的降低。

还有那个validation,我不明白为什么要 单独弄出一个bean来,不能在真正的entity里,在需要验证的字段上加个annotation,然后在业务层,需要更新或者保存时用 反射 检验一下?

当然 如果使用了hibernate等 可以直接用他的validation
15 楼 showr 2010-03-29  
标题党

是在没看到什么架构的东西。。。

害我白高兴一场
14 楼 li445970924 2010-03-29  
这是架构设计么 怎么感觉像是在讨论extjs啊
13 楼 felixshao 2010-03-29  
lkj107 写道
多大的项目啊,用extjs

如果客户的浏览器是IE6,打开界面是需要时间的

我们是做产品的,100多号人干了10年,最近用Extjs把所有的页面重写,因为我们做企业应用,每个客户End user 不超过100 人。
12 楼 felixshao 2010-03-29  
Domain Model 的设计:
   Domain Model分为两部份: 一部分叫Core Model,另一部分叫Extended Model,Core Model基本上就是一树状结构的Model, 因为是静态构建,所以没什么特别, Extended Model 是动态构建。

Core Model                   Extended Model
    Parent

    Child------------------  ExtendChild

    GrandChild-------------  ExtendGrandChild
 
    Grand-GrandChild-------  ExtendGrandGrandChild


chlid 与 ExtendedChild 是1 对 1 的 Primary Key Mapping。

GrandChild与 ExtendGrandChild 是1 对 1 的 Primary Key Mapping。

Grand-GrandChild与 ExtendGrandGrandChild是1 对 1 的 Primary Key Mapping。
Parent与 Child是1 对 多 的 Mapping。
Child与 GrandChild是1 对 多 的 Mapping。
GrandChild与 Grand-GrandChild是1 对 多 的 Mapping。

Extended Model 的所有Object都是动态读xml生成,然后再读另外一个配置文件Map到Core Model组成真正Domain Model。

具体实现用了EMF。
11 楼 fenxue 2010-03-29  
这个你们编程规范约定
10 楼 lkj107 2010-03-29  
多大的项目啊,用extjs

如果客户的浏览器是IE6,打开界面是需要时间的
9 楼 mr.a 2010-03-29  
erikchang 写道
看到EXTJS就感觉不是很好,使用css+div可以达到同样的效果,而不需要那么多的js

显示效果没问题, 功能上有时候还真达不到...
8 楼 GRDJE 2010-03-29  
这也叫架构, 最多算个编程规范》。。。
7 楼 felixshao 2010-03-29  
4. Validation 的处理:
  Validation是一个难点。页面上每一个Field都有可能要Validate,至少查空。第一步要把Field与Domain Model中的POJO 做映射。具体实现是:每一个页面的Screen Section对应一个Java ScreenBean,Field 与 ScreenBean的属性对应, annotate ScreenBean的属性(映射Domain Model中的POJO)。
举例:
页面某一个Section显示地址的一部分:
City Name, Street Name


要建立一个ScreenBean:

package com;

public class CityAndStreetBean {

@modelProperty("Address.city")
private String CityName;
@modelProperty("Address.street")
private String StreetName;


public void setCityName(String cityName) {
CityName = cityName;
}
public String getCityName() {
return CityName;
}
public void setStreetName(String streetName) {
StreetName = streetName;
}
public String getStreetName() {
return StreetName;
}
}



Domain Model 里面有POJO
Address 有 以下属性
city,street,和Country  

映射就建立起来了。建立映射的目的:
举例:
当用户在页面输入城市为:北京
而Domain Model中Address的Country为美国,可认为用户城市选择错误。

每个Service定义好想要Validate的内容,通过AOP配成before advice,因此必须Validation成功才能调用Service,否则返回提示信息给用户。
6 楼 felixshao 2010-03-29  
其实使用Extjs会减少很多代码。 首先,当你设计时必须把它想象成OO语言。第一步要把Class 图画出来, 把继承关系搞清楚。 例如我们有很多页面里都有Grid,因此我们有一个GeneralGrid Class 继承了GridPane,然后加了很多我们已经封装好的Function,自定义Events等。 具体每一个页面的Grid再继承GeneralGrid。
我想JQuery的功能Extjs里面都有了, 大家实现的东西不一样。
我不是偷懒,只是不上代码很难说清楚。 我想整理一下再放上来。
5 楼 qiren83 2010-03-29  
同意楼上 至多用个JQUERY 不要EXTjs 傻瓜化的东西的另一面是约束性大
拒绝YUI extjs
4 楼 erikchang 2010-03-28  
看到EXTJS就感觉不是很好,使用css+div可以达到同样的效果,而不需要那么多的js

相关推荐

    股权架构设计实操手册.pdf

    在顶层架构中,手册还介绍了不同类型的股份公司的股权架构设计,包括有限公司、非公众股份公司、新三板公司和上市公司。每种类型的股份公司都有其特定的股权架构设计要求。 第二部分 主体架构 在主体架构中,手册...

    华为企业架构总体架构设计方法.pptx

    企业架构是一项非常复杂的系统性工程,需要将业务能力分析、端到端流程分析、传统架构设计(TOGAF)和领域驱动设计(DDD)方法相结合,形成符合公司数字化转型发展要求的新版企业架构总体框架(CSG-EAF 2.0)。...

    新考纲-系统架构设计师(软考高级) 一站式通关课程(2024版)

    一、什么是软考 软考,全称计算机技术与软件专业技术资格(水平)考试,是一项由国家人力资源和社会...软件架构不仅指定了系统的组织结构和拓扑结构,并且显示了系统需求和构件之间的对应关系,提供了一些设计决策的

    系统架构设计师教程_第5章_软件架构设计

    软件架构设计是软件开发过程中的关键环节,它决定了软件系统的整体结构、组件及其相互关系,以及如何满足功能需求和非功能需求(如性能、安全性、可维护性等)。良好的软件架构设计能够确保系统在面对未来变化时具有...

    系统架构设计师考试全程指导.pdf

    本书内容涵盖了最新系统架构设计师考试大纲的全部知识点,包括但不限于软件架构设计的基础理论、架构模式、架构评估、架构决策、架构设计原则、架构风格、架构分析和设计方法、系统集成、分布式系统、安全性、性能、...

    系统架构设计师考试大纲.docx

    系统架构设计师考试大纲详细解析 系统架构设计师考试是一项旨在评估并认证个人在计算机科学和信息技术领域,特别是系统架构设计方面专业能力的考试。通过这项考试,考生需展示他们能够根据需求规格说明书,结合实际...

    2009年最新:系统架构设计师教程(超清析PDF)

    本书作为全国计算机技术与软件专业技术资格(水平)考试指定用书,系统地介绍了系统架构设计师的基本要求和应掌握的重点内容。全书共分21章,对计算机网络基础、信息系统基础、系统开发基础、软件架构设计等诸多内容...

    数字化转型企业架构设计手册.pptx

    企业架构总体框架是企业架构设计的核心,企业架构是一项集成的框架,用于演进或维护已有的信息技术和引入新的信息技术,从而实现组织的战略目标和信息资源管理目标。企业架构将企业战略转化为企业变革的需求、原则及...

    系统架构设计师教程.pdf

    根据提供的信息,我们可以推断这份文档“系统架构设计师教程.pdf”是关于系统架构设计方面的教程。由于提供的部分内容仅包含重复的网址(www.TopSage.com),我们无法从中直接获取具体的教学内容。因此,我们将基于...

    2023年系统架构设计师备考必备资料

    最后,"2023年系统架构设计师备考学习计划.pdf"是对当前考试年份的针对性学习指导,可能会包含新的考试大纲、重点难点分析以及学习路径推荐。这份文件可以帮助考生了解今年考试可能的变化,调整学习方向,确保复习的...

    产品技术开发项目-软件架构设计模板

    《产品技术开发项目-软件架构设计模板》 软件架构设计是构建高质量软件产品的重要环节,它为项目的实施提供了蓝图和指南。本文档旨在为产品经理、项目经理、系统工程师、架构师及软件开发人员提供一个清晰、全面的...

    软件平台架构设计与技术管理之道.docx

    "软件平台架构设计与技术管理之道" 本文总结了软件平台架构设计与技术管理之道的重要性、架构设计要点...只有通过合理的架构设计和技术管理,我们才能开发出高质量的软件系统,满足用户的需求,提高软件项目的成功率。

    系统架构设计师教程 系统架构设计师教程

    系统架构设计师教程 系统架构设计师教程 系统架构设计师教程 系统架构设计师教程 系统架构设计师教程 系统架构设计师教程

    系统架构设计师教程(软考)划重点版本

    在计算机组成与体系结构这一章节中,讲解了系统架构的基础知识,强调即使作为系统架构设计师,理解硬件和底层原理的重要性。计算机系统由硬件和软件构成,可视为多级层次结构。硬件部分包括: 1. 控制器:负责分析...

    系统架构设计师教程第二版

    - 新技术对架构设计的影响。 #### 三、案例分析中的核心理论与实践 1. **信息系统架构**: - 传统架构与现代架构的区别。 - 不同业务场景下的架构选择。 - 实战案例分析。 2. **层次式架构**: - 层次式架构...

    系统架构设计师教程(清华版)-无水印-无加密-高清最新版.pdf

    系统架构设计师教程(清华版)-无水印-无加密-高清最新版

    系统架构设计师 设计模式

    《系统架构设计师 设计模式》是一本针对软考系统架构设计师考试的重要参考资料,它深入探讨了软件架构设计中的核心概念——设计模式。设计模式是软件工程中经过实践验证的、解决常见问题的有效方法,是软件开发人员...

Global site tag (gtag.js) - Google Analytics