热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

模型的实现

一、第一个模型(视图类):列表模型当然是数据区的列表展示,这一模型作为系统的默认初始模型,模型名称为:INIT,SECTION值的命名为:INIT_DEFAULT,作为列表模型的一

一、第一个模型(视图类):列表模型

当然是数据区的列表展示,这一模型作为系统的默认初始模型,模型名称为: INIT, SECTION值的命名为: INIT_DEFAULT,作为列表模型的一个默认的实例。如果有第二个模型可以命名为 INIT_DEFAULT2 的方式进行,实事上很少用到第二种模型实例,不过由于默认的集成了新建,导入、导出等一系列功能性的接口,还缺失一个数据只读的模型,所以又增加了一个模型实例:INIT_CUSTOMER,用以做数据只读的列表。

必须的模型属性里面定义的属性有:

1. tablename = hrms_file

定义模型对象的名称,在数据映射里面这里是指数据库表的名称。一般情况下都有一个 MDA 驱动单元定义,这里重新定义对象名称是可以让一个 MDA 驱动单元包含不同的对象,可以对不同对象的不同模型进行数据映射和处理。

2. tabletitle = listhrms_file

定义模型显示的标题内容,此部分显示的文本通过一个Common_Html变量过滤全局信息, html_etc变量过滤区域信息,从而支持中文和英文两种界面语言,以后遇到界面语言
过滤的作法不再详细说明。

3. tablewidth = 100%

定义模型显示的宽度,支持直接宽度百分比宽度表示。默认值为百分比表示:80% 。
文法:TableWidth = 80% or Tablewidth = 600。

4. ondblclick_cOnfig= init_edit

定义模型在数据列表中,用户双击行记录时所发生的操作,系统支持两种操作,一是针对该行记录的读操作,二是针对该记录的编辑操作。默认为对该记录的读操作

文法解析:init_view 针对该记录的读操作;init_edit 针对该记录的写操作。

5. nullshow = 1

定义模型在没有数据的状态下,显示的类型表示。真值时表示可以显示没有数据时的结构信息;假值时会提示没有数据。主要用于用户是否有权限增加数据时用到。

用户有用户界面接口权限时如果被定义只有只读权限,那么这个可以被设定为假值;如果被定义为有写写权限时,那么可以被设定为真值;默认值为真。

附:该属性为刚开始设计时所用属性,在设计形成以后,该属性很少用到,不过做了保留

6. action_model = add_default:new:n,export_default:export:x,import_default:import:i

定义模型行为区的可选动作。主要分为新增操作导出操作导入操作等。系统初始化默认时三种操作都被含有。如果被定义为只读操作,那么可以新增操作屏蔽,同理也可以对其它两种操作进行定义。

文法解析:
add_default:new:n :add_default 为动作行为引发新模块的名称,new 为动作的界面语言表示,n 为快捷键表示,使用文法:Alt+n ;
export _default: export:x :export _default 为动作行为引发新模块的名称, export为动作的界面语言表示, x 为快捷键表示,使用文法:Alt+x ;
import _default: import:i :import _default 为动作行为引发新模块的名称, import为动作的界面语言表示, i 为快捷键表示,使用文法:Alt+i。

7. row_element = view:view_default,edit:edit_default,delete:delete_array

定义模型数据区每行操作部分的操作属性定义。主要分为行记录查看,行记录编辑,行记录删除三种行单元操作。三种操作均可以自由选择,以适应不同的权限要求。

文法解析:
view:view_default :行记录查看操作,view 为行记录界面语言表示,view_default 为行记录引发新模型的模型名称表示。
edit: edit _default :行记录查看操作,edit为行记录界面语言表示,edit _default 为行记录引发新模型的模型名称表示。
delete: delete _default :行记录查看操作,delete为行记录界面语言表示,delete_array 为行记录引发新模型的模型名称表示。

8. bottom_element = chooseall:chooseall,delete:delete_array,edit:edit_default
9. primarykey = 0

定义模型对象属性中关键属性的索引值。默认为 0,即对象的第一个属性的索引值。

文法解析:主要用于标记录的唯一性,查看,编辑,删除操作中都以其为主。

10.uniquekey = 0

定义模型对象属性中唯一属性的索引值。默认为 0,即对象的第一个属性的索引值。
文法解析:主要用于防止非重复数据输入。

11. systemorder = 0:desc
12. pagenums_model = 25
13. action_search = 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,2

定义模型搜索区中要搜索的表字段属性索引列表。从0开始,用引索引表示,之间用”,”分隔。

14. group_filter = 3:department:1:1,4:hrms_zhiwei_status:1:1,8:gb_national:1:1

定义模型分组区要进行外部分组的对象属性信息定义。每一分组信息中含有父对象名称,KEY 值,NAME 值,以及相联系的参数值索引。不同的对象分组信息之间同样用”,”分开。

文法解析:
3:department:1:1 :3本对象的关联属性索引值,department 父对象数据库表名称,1父对象 KEY值,1 父对象 NAME值。
3:user_priv:0:1 :3 本对象的关联属性索引值,user_priv 父对象数据库表名称,0 父对象 KEY 值,1 父对象NAME 值。


15. showlistfieldlist = 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26

定义模型数据区中要显示的表字段属性索引列表,之间用”,”隔开。

16. showlistnull = null,null,null,null,null,null,null,null,null,null,null,null,null,null,null

定义模型数据区输入数据的合法性判断,主要用在ADD 和EDIT模型中,为了使模型结构上保持一种相近性,此属性被保留在INIT 属性中,但在 INIT 中没有使用到。

17. showlistfieldfilter = input,input,tablefiltercolor:department:1:1,userdefine:renshiguanli

定义模型数据区数据的过滤信息定义,与 ShowListFieldList相对应,不同的对象属性在 Filter中按相应的顺序排列,定义其相应属性的过滤附加信息。
文法:ShowListFieldFilter = input ,link:chart_default,password,tablefilter:user_priv:0:1
文法解析:
input:系统默认数据,无过滤
Link:chart_default:联接信息,URL 形式表现,以”:”分隔,前部分是定义类型,后一部分是引发新模型的名称信息。
Password:密码信息过滤,过滤去密码密文信息,统一用”*****”表示。
Tableiflter:user_priv:0:1:表过滤类型;Tablefilter为定义类型为表过滤,user_priv定义父对象名称,0 定义 KEY值,1 定义NAME值。

二、 第二个模型 (视图类):视图模型

对单条记录的查看视图。刚开始设计的时候,查看视图里面也集成了功能性按钮,如新建、编辑、删除等,所以视图模型也分为两个,和第一个模型进行对应,一个有操作区,一个没有操作区,不过后来取消了这样的设计,所的视图全是只读区,不允许其在视图区进行新建、编辑和删除操作。

模型属性定义:

1. tablename = hrms_file
2. tabletitle = viewhrms_file
3. tablewidth = 65%
4. action_submit = print:print:p,cancel:cancel:c
5. primarykey = 0
6. subtablecount = 0
7. uniquekey = 0
8. showlistfieldlist = 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19
9. showlistnull = null,null,null,null,null,null,null,null,null,null,null
10. showlistfieldfilter = input,input,input,input,input,date,input,input,
11. showlistfieldstopedit = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
12. showlistfieldstopdelete = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,

三、第三个模型(视图类):新建模型

主要是对表的新增操作。模型属性定义:表名称,模型宽度,表标题、表字段、表过滤类型、模型返回。数据新建完成以后,返回系统定义的模型实例,一般为 INIT_DEFAULT模型实例。

模型属性定义:

1. tablename = hrms_file
2. tabletitle = newhrms_file
3. action_submit = submit:save:s,cancel:cancel:c
4. primarykey = 0
5. subtablecount = 0
6. uniquekey = 0
7. returnmodel = init_default

定义模型对象数据处理完以后,界面返回的模型名称。一般情况下会返回到 INIT_DEFAULT 模型,可以根据需要返回到ADD_DEFAULT,VIEW_DEFAULT 等模型。 

8. showlistfieldlist = 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24
9. showlistnull = notnull,notnull,null,null,null,null,null,null,null,null,null,null

定义模型数据区输入数据的合法性判断,主要用在 ADD 和EDIT 模型中。 
文法解析:notnull 输入验证非空 ;null 输入可以空值。

10. showlistfieldfilter = input,input,depttoname:1,tablefilter:hrms_zhiwei_status:1:1
11. showlistfieldstopedit = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
12. showlistfieldstopdelete = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
13. showlistfieldprivate = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,

四、 第四个模型(视图类):编辑模型

主要是对表的新增操作。模型属性定义:表名称,模型宽度,表标题、表字段、表过滤类型、模型返回。数据新建完成以后,返回系统定义的模型实例,一般为 INIT_DEFAULT模型实例,也有一部分返回查
看视图 VIEW_DEFAULT模型实例,不过很少这样使用。

1. tablename = hrms_file
2. tabletitle = edithrms_file
3. action_submit = submit:save:s,cancel:cancel:c
4. primarykey = 0
5. subtablecount = 0
6. uniquekey = 0
7. returnmodel = init_default
8. showlistfieldlist = 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,2
9. showlistnull = notnull,notnull,null,null,null,null,null,null,null,null,null,null

10. showlistfieldfilter = input,input,depttoname:1,tablefilter:hrms_zhiwei_status:1:1
11. showlistfieldstopedit = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
12. showlistfieldstopdelete = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,
13. showlistfieldprivate = ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,

五、第五个模型(导入类):导入模型

主要是对表的批量导入操作。模型属性定义:表名称,模型宽度,表标题、表字段、表过滤类型、模型返回。数据新建完成以后,返回系统定义的模型实例。一般模型实例为 IMPORT_DEFAULT。

模型的实现


推荐阅读
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
author-avatar
阳光-假日
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有