PB通用类库和业务类库的设计思想(二)
PB通用类库和业务类库的设计思想(二) 二、UFC通用类库框架
(一)UFC通用类库简介
UFC(User Foundation Class)类库是一组PowerBulider的对象,它是由许多通用对象组成的基础类库。主要包括权限管理对象、错误截获对象、应用程序管理对象、事务管理对象、数据窗口服务对象、窗口对象等。
类库主要包括以下几个包:
1、五个核心包
UFCAppSrv.pbl 应用对象服务包,包括应用程序管理对象、字符串操作对象、数值操作对象等。
UFCMain.pbl 通用对象服务包, 包括PB的标准对象的各种扩展对象:窗口、数据窗口、编辑框、图片按钮等。
UFCObjSrv.pbl 定制对象服务包, 大部分是一些定制的用户对象,例如工具条、OutLook条等。
UFCDwSrv.pbl 数据窗口服务包,包括各种数据窗口服务,例如过滤服务、查找服务、排序服务、弹出菜单服务等。
UFCWnSrv.pbl 窗口服务包,包括数据窗口上的扩展服务,例如状态条服务、个性化风格服务等。
2、两个辅助包
UFCTemplate.pbl 模板对象包, 包括各种模板窗口。
UFCCommon.pbl 公共业务对象包, 包括MIS系统的一些通用业务窗口和数据窗口,例如权限管理窗口、系统参数管理窗口等。
3、可选包(可以根据需要包含)
UFCExternal.pbl 外部扩展对象包,包括各种第三方PB对象,以及API相关对象。
UFCDatabase.pbl 数据库对象包,包括对各数据库对象的统一封装,以及业务帐套的管理。
4、工具包(可以根据需要包含)
UFCReport.pbl 通用报表对象包,提供了一个通用的报表工具。
UFCUpdate.pbl 自动升级对象包,提供了一个最新程序上载和更新的工具。
UFCStatistic.pbl 通用数据统计分析图表包,提供通用的对数据的统计和分析工具,以及图表显示。
(二)UFC通用类库命名规范
1、UFC对象的命名
所有基础类库的对象(包括所有的结构体和全局函数), 其名称都带前缀ufc_,加上这个前缀的好处是让业务对象与类库对象区别开来, 而不会产生重名的麻烦: ufc_type_objectname
具体类型说明如下:
前缀 描述
ufc_m_ Menu
ufc_n_ Standard class user object
ufc_n_ Custom class user object
ufc_s_ Global structure
ufc_u_ Visual user object
ufc_w_ Window
例如:
例子 解释
ufc_w_base 所有窗口的基类
ufc_u_tv TreeView控件基类
ufc_u_dw DataWindow控件基础类
ufc_n_dwsrv 数据窗口服务基础类
ufc_n_tr 不可视的事务对象基础类
2、UFC对象实例命名
所有对象实例采用PB中标准的命名方式, 采用(对象类型缩写)+(_)+(实例英文描述)
例如: dw_Master , w_Logon 等。
3、UFC变量命名
所有变量和PB中默认的命名方式一致, 采用 (作用域)+(类型)+(_)+(变量英文描述)
例如: gnv_App li_Index is_UserName 等。
4、UFC基础类库中事件和函数命名
所有自定义事件(非系统事件), 都采用 (ufc_)+(事件描述)的方式, 例如: ufc_Open
对于一个事件的前触发和后触发, 采用(ufc_Pre)+(事件描述)表式前触发, 采用(ufc_Post)+(事件描述)表示后触发, 例如: ufc_PreOpen , ufc_PostOpen。
对于函数, 采用 (of_)+(函数描述)的方式, 例如 of_GetUserName() 。
(三)核心包分析
UFC基础类库主要采用窗口、标准用户对象、定制用户对象来实现面向对象封装。主要的服务有:
1、应用程序管理对象(ufc_n_AppManage),实现整个应用程序的管理,以及对应用系统全局变量的封装。它包含的服务主要有:
A。系统参数对象(ufc_n_SysParam),提供了对业务系统数据库中的各种全局参数的访问。
B。错误日志对象(ufc_n_Error), 提供了对系统中各种错误的捕获,最后统一记录和显示出错信息。
C。事件日志对象(ufc_n_EventLog),提供了每个系统登录用户的登录细节,以及对系统的操作情况。
D。系统序列号对象(ufc_n_Sequence), 提供定义系统中各种编号的规则定义,以及各种编号的自动生成。
E。权限管理对象(ufc_n_RightManage), 提供了一个统一的权限管理对象,通过它来获取登录用户对每个模块的访问权限(ufc_n_Right),所有权限感应对象根据传递给它的ufc_n_Right来初始化其自身表现。
2、窗口对象和窗口服务对象
主要的几个窗口基类说明:
ufc_w_base --是所有窗口的基类,封装了一些与业务无关的通用功能。
-ufc_w_master --为了扩展一些API效果,在UFCMain.PBL或UFCExternal.PBL中实现。
--ufc_w_frame --MDI窗口基类
---ufc_w_navigateframe --导航式的MDI窗口模板
--ufc_w_main --业务窗口基类,实现了与数据窗口的关联和事件映射。
---ufc_w_sheet --业务子窗口
--ufc_w_popup --Popup风格窗口基类
--ufc_w_response --Response风格窗口基类
主要的窗口服务有:
A。状态条服务, 为PB中的MDI窗口提供多功能的状态提示条。
B。工具条服务, 提供对PB中的标准工具条的操作界面。
C。桌面配置服务, 对应用程序的整体外观进行配置,包括导航条、状态条、工具条的开关,窗口位置的保存等。
D。墙纸服务,提供在应用程序的MDI区显示背景图片。
E。个性化偏爱服务, 提供了对窗口配置的自动读取和设置。
3、数据窗口对象和数据窗口服务
整个基础类库就是对数据窗口的扩展,为了不导致数据窗口对象的过度膨胀,把各种服务功能独立成一个服务对象,而在数据窗口中采用引用服务对象的方式来实现。 其中主要的数据窗口服务有:
A。排序服务(ufc_n_dwsrv_sort) B。过滤服务(ufc_n_dwsrv_filter)
C。查询服务(ufc_n_dwsrv_query) D。检索服务(ufc_n_dwsrv_retrieve)
E。自动保存服务(ufc_n_dwsrv_autosave) F。数据导出服务(ufc_n_dwsrv_export)
G。数据导入服务(ufc_n_dwsrv_import) H。下拉查找服务(ufc_n_dwsrv_dropdownsearch)
I。链接服务(ufc_n_dwsrv_linkage) J。多表服务(ufc_n_dwsrv_multitable)
K。弹出菜单服务(ufc_n_dwsrv_PopMenu) L。弹出选择服务(ufc_n_dwsrv_PopSelect)
M。行管理服务(ufc_n_dwsrv_rowmanage) N。行选择服务(ufc_n_dwsrv_rowselect)
O。重复列判断服务(ufc_n_dwsrv_repeate) P。要求列判断服务(ufc_n_dwsrv_Required)
Q。初始化列服务(ufc_n_dwsrv_initcolumn) R。改变大小服务(ufc_n_dwsrv_resize)
S。日历服务(ufc_u_Calendar) T。计算器服务(ufc_u_Calculate)
U。错误记录服务(ufc_n_error) V。弹出按钮服务(ufc_u_PopButton)
4、全局服务对象
主要有以下服务对象:
A、字符串操作对象(ufc_n_String) --包括对字符串的分割、全局替换等。
B、日期时间操作对象(ufc_n_DateTime) --包括对日期时间的增减、日期字符串的转换等。
C、数值操作对象(ufc_n_Numerical) --包括对数值的转换,包括金额的大小写转换等。
D、类型转换对象(ufc_n_Conversion) --提供对各种枚举与基本类型之间的转换。
E、平台对象(ufc_n_PlatForm) --提供对操作系统平台的支持。
F、SQL对象(ufc_n_SQL) --对SQL语句进行解析和拆分
类库的基本框架大体上就是这样, 它们之间具体怎么关联的, 请听下回分解。
(待续)