驰骋工作流引擎-表单设计器操作手册-ccflow5.docx
做最好用的工作流程引擎,BPM系统,奉献社会。驰骋表单设计器操作说明书济南驰骋信息技术有限公司2013年1月修订目录1总体说明61.1前言(必读)61.2一种存储格式(同一个表单)61.3两种表单设计器(同一个表单)71.3.1傻瓜表单设计器71.3.2自由表单设计器71.4四种展现方式(同一个表单)81.4.1傻瓜表单81.4.2自由表单91.4.3手机表单91.4.4 Silverlight表单101.5自由表单设计器预览111.6傻瓜表单设计器预览111.7表单样本121.7.1企业基本情况121.7.2财务负责人简历131.7.3从表导入导出131.7.4多表头从表141.7.5从表的卡片表现形式141.8表达式全局变量152调用API162.1与工作流程引擎API162.2与应用操作的API162.3 ccform的内置JS函数(开发者必读)163自由表单的工具箱-控件分类说明173.1装饰类控件:183.1.1线183.1.2标签183.1.3装饰图片193.2字段类对象193.2.1文本框, 日期时间框, 选择框, bool类型控件.193.2.2下拉框(枚举类型)223.2.3下拉框(物理表或视图)233.2.4单选按钮(枚举类型)25隐藏字段273.3 附件类控件273.3.1单个表单附件273.3.2多表单附件283.3.3手写板303.3.4图片附件313.4关系类控件333.4.1从表(从表)333.4.2一对多的关系表353.4.3一对多多关系表373.3功能类控件373.3.1按钮373.3.2鼠标423.3.3选择423.3.4超连接424表单设计器功能434.1属性:434.2保存:444.3预览:444.4导出:454.5导入45从ccflow网站上导入:46从本机导入:46从节点表单导入:46从流程表单导入:464.6全选464.7复制464.8粘贴464.9对齐方式按钮464.10删除474.11撤消(未实现)474.12恢复(未实现)474.13加粗474.14斜体474.15删除线474.16增益474.17减益474.18调色版484.19表单事件48事件类型:49页面装载前49页面装载后49保存前49保存后495字段扩展设置495.0 表单装载前数据填充505.1数据获取51方式1:本表单中数据计算52方式2:利用SQL自动填充.52方式3:本表单中外键列。53方式4:对一个从表的列求值。535.2级联下拉框53主表中的级联53从表中的级联55常见问题565.3表单字段的输入js脚本验证56设置步骤56如何设置自定义验证函数?56脚本验证的工作原理57如何通过获取表单控件值(使用ccform内置函数)?57如何在提交前做一个完整的表单输入验证?585.4自动完成595.4.1 演示环境说明595.4.2主表中的自动完成595.4.2主从表的自动完成605.4.3从表中的自动完成615.5 字段超连接62在主表表单设计上的表现63在从表的表现与设计645.6 Pop返回值64概述与事例:64内置popval窗体设置方式65自定义url设置方式676从表的设计686.1从表的设计器686.2从表的属性686.3从表属性说明696.3.1操作权限控制696.3.2是否起用审核字段:706.3.3是否启用多附件706.3.4显示格式716.3.5越位处理736.4 从表事件746.5为从表设计导入数据模版756.6 从表的多表头设计767一对多的关系设计777.1什么是一对多的数据关系?777.2一对多的关系设计787.3数据存储格式是什么798 一对多多的关系设计808.1应用背景808.2设计方式808.3数据存储格式809表单的单据打印809.1单据打印总体概述809.2单据模板的制作809.3单据输出格式约定819.4单据生成的工作原理839.5单据表单的分类839.5.1节点表单839.5.2 流程表单849.6单据设计常见的问题8410表单事件8510.1事件概述8510.1.1事件类型解释:8610.1.2执行存储过程:8610.1.3执行自定义URL.8610.1.4执行系统URL8710.1.5未完成的开发8710.2主表事件8710.3从表事件8810.4事件的数据存储8811技术文摘8911.1常见问题类8911.1.1在表单设计器中,如何获取自由表单下拉框的值?8911.1.2如何用自由表单设计器映射我的物理表?9111.2 技术文摘9111.2.1如何利用ccform自定义表单来增加自己的控件,关于Sys_FrmEle表结构与数据存储设计.9111.2.2关于流程数据的从表数据汇总问题9311.2.3如何使用驰骋工作流程引擎的表单设计器做数据提交前的表单验证9311.2.4如何利用ccform中自定义函数实现对从表数据的一行数据输入的安全与逻辑验证?971总体说明1.1前言(必读)驰骋自由表单设计器有一种存储格式、两种设计模式,三种展现方式,具有一定的通用的接口可以被外部调用,自己有可以独立运行起来的应用程序。一种存储格式:采用映射的机制,以xml文件格式存储。两种设计模式:傻瓜表单设计器,自由表单设计器。三种展现方式:傻瓜表单、自由表单、手机表单。表单设计器以映射思想为核心。所说的映射业务规则对字段,操作方法,界面展现,操作行为的描述。表单设计者认为事物的业务规则与操作模式都是可以被抽象出来的,并且把其封装并实现。 但是并不是所有的业务规则都有价值去抽象,是否有价值去抽象并封装是应用的范围与实现的代价。由以上两个理论为指导,把界面所有的元素的描述,业务规则的描述以对象的形式为描述。 Ccflow 自由表单设计器不一定满足所有的数据采集与数据展现格式,但是可以解决对数据库操作层面的绝大多数需求。用户可根据自己的需要选择其中的一种表单的工作方式。1.2一种存储格式(同一个表单)Ccflow的表单存储格式与传统的表单存储格式不同,它是采用数据表的存储的,这是最大区别于文件格式的存储。正是因为ccflow摆脱了对文件格式存储的表单的依赖,所以具有最大范围的扩展性通用性、灵活性。物理表名中文名说明Sys_FrmLab标签存储标签Sys_FrmLine线存储线,线只分横线与竖线。Sys_FrmLink超连接超连接Sys_FrmImg图片图片Sys_FrmBtn按钮按钮,按钮支持多样的事件方式Sys_MapAttr字段存放三种类型的字段textbox,checkbox,dropdownlistbox.Sys_MapData表单主表Sys_M2M一对多Sys_M2MM一对多多Sys_FrmAttachment附件. 更多请参考程序代码.可以利用ccform 的导出功能把这些规则化的数据导出成一个xml。1.3两种表单设计器(同一个表单)驰骋公司根据用户群体不同,用户对界面的要求不同特开发了两种表单设计器,三种展示模式。自由表单设计器与傻瓜表单设计器,两者的存储格式都是一样的,就是展示与设计方式不同。1.3.1傻瓜表单设计器优点:设计方便,不需要排版,有分组显示功能界面简洁清晰,容易上手。缺点:不形象直观,不符合用户的需求格式。1.3.2自由表单设计器优点:设计方便,形象直观,随心所欲。缺点: 没有傻瓜表单简洁,需要排版,同样的功能没有傻瓜格式方便。1.4四种展现方式(同一个表单)对于一个表单来说有三种展现方式,至于用户使用那种表单是有流程的节点属性来设置的。1.4.1傻瓜表单优点:界面清晰、简洁、紧凑。缺点:格式固定。1.4.2自由表单优点:界面元素可以根据用户的需要任意排列。缺点:样式不能调整1.4.3手机表单手机填写主表:手机从表: 点上图中的费用明细就可以看到下面的从表查看界面。手机表单是手机表单特点1.4.4 Silverlight表单1.5自由表单设计器预览1.6傻瓜表单设计器预览1.7表单样本1.7.1企业基本情况企业基本情况(打印)与打印模板.1.7.2财务负责人简历具有附件图片1.7.3从表导入导出从表的导入导出1.7.4多表头从表企业代表工程业绩一览表(多级表头明细)1.7.5从表的卡片表现形式从表的卡片方式展现1.8表达式全局变量在系统中有很多的地方需要用到表达式的地方,这些表达式就需要参数与变量,这些参数是以+变量名。我们把参数与变量分为全局变量,字段变量。操作人员登陆系统后就有如下全局变量。WebUser.No 当前操作员编号WebUser.Name 当前操作员名称WebUser.FK_Dept 当前操作员部门AppPath 当前的文件路径。比如:http:/demo.ccflow.org/ccflow 变量用加变量名体现。比如:WebUser.No。以FF中,很多的表达式需要变量的支持。比如一个sql表达公式。SELECT No,Name, FK_Dept FROM PORT_Emp WHERE FK_DEPT=WebUser.FK_Dept注意区分大小写。表单字段变量:+字段名 比如:Select generBillNo(OID) from dual OID 就是表单字段。+字段名是获取界面上的动态输入的值。2调用API2.1与工作流程引擎API如何把Ccform 嵌入到工作流程引擎中去?(省略)2.2与应用操作的API如何使用Ccform 在我的应用程序中?调用连接 http:/localhost/XXXX/Ccform/Frm.aspx?FK_MapData=YYYYYYY对于表单的权限控制可见不可见来源来应用程序本身,对于表单内的按钮控制由Ccform 的按钮属性来确定的。2.3 ccform的内置JS函数(开发者必读)开发web应用程序必须要获取ccform的表单元素,然后在根据元素对象执行进一步的业务处理,比如保存数据安全性完整性的校验。Ccform为开发者,提供了内置函数,以下图为例:因为内置函数是在增加的、变化的所以列在说明书里没有意义,关于ccform的内置函数请参考: D:ccflowVisualFlowWFUCMyFlow.aspx.cs3自由表单的工具箱-控件分类说明工具栏中的对象分为装饰类控件、数据类的控件、与功能类的控件。鼠标:类型vs设计器中的鼠标功能,当您点了其它的功能按钮后,您想取消选择,就点此功能。选择:在画布画矩形在矩形内部的对象都被选择,比如对选择的线条的粗细进行+ - 。对颜色进行更换,对label 集合的字体颜色进行变化。标签:文字类装饰元素,标签的文字大小、类型、颜色,都可以变化。画线:线条的粗细、长度、颜色属性可以改变。超连接:功能类的控件,它有两部分组成标签与连接,标签部分的功能与标签功能一致。装饰图片:装饰类的控件,多用于把公司的icon图片放在上面。按钮:为了实现一些功能文本框:长度、高度、默认值都可以被编辑。日期框:长度固定选择框:Boolean类型的字段。下拉框(枚举):枚举类型下拉框。下拉框(表、视图):下拉框中是以表格为内容的。表单附件:可以是任何格式的控件。图片附件:比如简历的个人图片。从表:与主表之单的表格一对多的关系:比如与主表的关系,节点岗位,隐藏字段:不需要在表单上显示出来的字段,多用于值的计算,或者节点方向条件的转换。3.1装饰类控件:线、标签、装饰图片3.1.1线线是装饰类对象的基本元素。对于线的操作3.1.2标签标签是用来文字说明装饰,标签可以改变颜色,字体大小,风格等等。标签元素可以复制,选中后,ctrl+C Ctrl+V 就可以实现。支持鼠标移动, aswd 键,方向键移动。3.1.3装饰图片图片是表单元素的一部分。3.2字段类对象文本框、日期框、选择框、下拉框、单选按钮、表单附件、图片附件、从表、一对多的关系表、隐藏字段。3.2.1文本框, 日期时间框, 选择框, bool类型控件.说明:1, 日期与日期时间框不能改变大小,其它的类型的文本框可以改变大小。2, 要改变文本框的位置可以按下它的边框,然后移动,或者选中它,使用方向键移动。3, 改变文本框的宽度可以使用 shift + 方向键。 改变文本框的高度与宽度。属性编辑:如上图3.2.1.1使用自由表单设计器创建审核分组在表单设计中经常遇到领导审核、或者审批,这种审批与审核通常有三个字段组成分别是审核意见、审核人、审核时间。 审核意见是一个大块文本采集框、审核人是默认当前操作人员、审核时间就是当前时间。如果在自由表单设计器中一个个的字段添加也是可以的,ccform为了提高设计者的效率与傻瓜表单设计器一样推出增加审核分组功能。如下图:填写说明见上图:如果审核分组的字段前缀是CW,那系统就会创建三个字段分别是CW_Checker审核人 , CW_RDT审核日期,CW_Note审核意见。同时也建立了一个字段分组,条理化规则的显示在傻瓜表单设计器中。3.2.1.2 创建隐藏字段隐藏字段的用途?隐藏字段不体现在表单里,隐藏字段一般用于计算临时计算,在节点表单中做为方向条件。如何创建与编辑隐藏字段?在创建正常字段时您是是否是隐藏字段勾上,如果要编辑隐藏字段在工具栏里有一个隐藏字段图标。3.2.2下拉框(枚举类型)新建枚举类型3.2.3下拉框(物理表或视图)关键字:ccform 外键表 外键字段对于一个表单来说外键是经常遇到的,ccform为我们提供系统的基础表(Port_Emp,Port_Dept, CN_PQ ,CN_SF,CN_City,),当然也可以把自己定义外键表,或者说字典表。在您初始化系统后,您可以打开SELECT *FROMSys_SFTable你将会看到一些演示的数据。外键实体分为物理表类型与系统类库. 用类库可以很好的控制查询权限,比如人员查询权限,在表单中只列出该操作员的部门人员。部门类可以控制只查询本人的部门与本人的下级部门。如果用物理表就没有这个概念了。外键表存储在Sys_SFTable 系统表中,您可以通过界面维护它,也可以手工的维护它。如果您手工的维护(注意:SFTableType此字段已经不用了)。对于Sys_SFTable 列描述如下:No: 外键,Name: 表名称,FK_Val 在创建外键字段时默认的外键字段名称TableDesc: 描述。IsEdit 是否可以编辑。 如何把ERP,OA,CRM应用程序中的物理表对应到ccform中去?首先把应用系统的物理表通过视图映射到ccflow 可访问的数据库中来,这个表或者视图必须有No,Name,两个列。其次把这个数据维护到Sys_SFTable中去。3.2.3.1 自定义表列表3.2.3.2 创建与编辑3.2.4单选按钮(枚举类型)单选按钮是枚举值的一种表现形式。选择枚举设计样式浏览样式隐藏字段用于存储临时计算值,在节点表单中,经常被用到方向条件。在您创建文本框时您如果选择了隐藏字段,系统就会把此字段不体现在表单设计器中。在创建正常字段时,您只要把是否是隐藏字段勾上就可以了。3.3 附件类控件3.3.1单个表单附件文件是以上传一个文件保存到服务器上,如下图所:附件的格式需要以, 分开比如:*.doc,*.docx,*.txt拖放后:预览表现:3.3.2多表单附件多表单附件是用户上传的附件格式不能确定,数量不能确定情况下使用。设计步骤:在工具栏点多附件按钮,如下图: 多表单附件属性:附件名称:就是为控件起一个名称,附件编号需要全局唯一。保存到是文件要保存的位置。是否可下载,是否可删除,是否可上传是用来控制附件的访问权限的。特别说明:类别可以为空,如果不为空时系统就会自动为它附件按约定的格式分类。两种附件的展现模式:3.3.3手写板3.3.4图片附件图片附件与文件附件不同的地方就是图片附件需要预览。比如:我们做一个简历表单,需要把人员的照片放在指定的位置。设计方式:1, 在工具栏中找到图片附件。2, 用shift+ 方向键改变图片的大小。预览效果如下图。编辑与上传图片:点编辑连接,系统弹出如下对话框。可以把剪切的图片点确定按钮,返回。3.4关系类控件3.4.1从表(从表)从表也叫从表。设计界面从表属性界面预览与操作界面点选项按钮3.4.2一对多的关系表一对多的关系是对多项选择来确定的。比如:单位人员旅游名单。这些名单可以让用户去选择它。运行界面属性编辑显示在分组,对所有的自由表单设计器来说无意义。3.4.3一对多多关系表一对多有三个维度第一维度是 对象列表. 他有两种表达方式。 1, sql 必须有两个列 No,Name. 2, +本表单中的多对多编号. 第二维度是: 如同 m2m 中的第一维度. where 表达公式中需要一个 Key 就是来自于第一维度的 实体 PK. 第三维度是: 如同 m2m 中的第二纬度.3.3功能类控件按钮,鼠标、选择,超连接。3.3.1按钮表单上面的按钮对象,可以处理事件内容。特别说明:ccflow所有的事件内容的处理方式都是一致的,目前所涉及的事件有,表单事件、按钮事件、流程事件。总体说明每个按钮有自己的按钮类型,使用自定义按钮类型。属性说明按钮事件类型事件类型决定按钮执行的内容。事件内容就是要执行的内容,内容里面可以有变量,变量来自与表单。变量的表达方式仍然用+变量名来决定,比如:jiner , shenpiren, 系统变量有WebUser.No 当前操作员编号,WebUser.Name 当前操作员名称 WebUser.FK_Dept 当前操作员部门。执行成功提示信息当内容执行成功时提示的信心。执行失败提示信息当内容执行失败时,抛出异常信息时提示的信息。执行存储过程案例说明:WebUser.No 表示当前的操作人员系统变量。执行SQL 事例以上事例说明了删除一条数据时提示的信息。+字段名是用来取当前节点字段。执行URL特别说明:执行url 是静默执行,需要对方的页面直接返回 string 串就可以了。如果超时连接,或者,返回串的前三个字母是Err ,ccflow就会执行失败,就抛出失败信息给操作者。在执行url时系统就会把两个默认的参数增加上。分别是UserNo, SID。比如:您设定的是 http:/serverName/a.aspx?type=MyType 实际执行的是:http:/serverName/a.aspx?type=MyType&UserNo=abc &SID=a2345bc执行JavaScript执行js 时,成功信息与失败提示信息就不需要填写了。3.3.2鼠标点它就是取消所有的工具选择。3.3.3选择全选特定的区域,比如要删除特定区域的对象,就可以使用它来选择。3.3.4超连接显示超级连接.提示:符号表示换行。4表单设计器功能4.1属性:用来控制表单的基本属性如果画布不够宽度与高度可以通过设置此属性来满足。4.2保存:保存当前的设计,在设计过程中多执行保存并预览按钮。目前的保存具有保存与预览的功能。4.3预览:浏览当前的设计。4.4导出:导出ccform模板。导出ccform模板并共享。4.5导入把当前的设计导出xml模板。从ccflow网站上导入:在ccflow官方网站上有一些网友共享的表单模板,通过他们方便的导入进来。从本机导入:导入存储在本机上的表单模板。从节点表单导入:从其它节点上导入表单进行二次编辑。从流程表单导入:从流程表单上导入表单进行二次编辑。4.6全选选择全部的元素,一般用于全部删除,全部平移对象,目前不太成熟。4.7复制复制选择的元素,到内存里。4.8粘贴只有如下对象支持粘贴:线,标签,文本框。4.9对齐方式按钮左对齐在选择多个同类的控件时,比如:标签、线、文本框,执行此按钮会执行左对齐。居中在选择多个同类的控件时,比如:标签、线、文本框,执行此按钮会执行居中。右对齐在选择多个同类的控件时,比如:标签、线、文本框,执行此按钮会执行左对齐。顶部对齐在选择多个同类的控件时,比如:标签、线、文本框,执行此按钮会执行左对齐。底部对齐在选择多个同类的控件时,比如:标签、线、文本框,执行此按钮会执行底部对齐。4.10删除删除选择元素,如果选择的元素有多条,就要删除选择的元素集合。4.11撤消(未实现)撤消上一步的操作。4.12恢复(未实现)恢复上次的操作。4.13加粗对标签字段加粗,可对标签控件批量执行。4.14斜体对字体设置成斜体,可对标签控件批量执行。4.15删除线对字体设置成删除线,可对标签控件批量执行。4.16增益如果选择的是线条:点一次就增加一个像素的宽度。如果选择的是标签:点一次就增加一个字体的大小。4.17减益如果选择的是线条:点一次就减小一个像素的宽度。如果选择的是标签:点一次就减小一个字体的大小。4.18调色版用来改变线条,标签的颜色。4.19表单事件每个事件的填写内容都是一致的:事件类型:事件类型就是执行的方式,您可以根据自己的需要来选择执行方式。目前支持的事件内容:执行存储过程,执行sql, 执行url, 执行JS脚本。在执行内容中,执行成功信息提示,执行失败信息提示都支持字段名类型的参数。执行内容约定: 请参考本章节:Button 事件内容约定。对异常的处理:当对执行的内容失败时,系统就会把执行失败的信息提示出来。比如:在执行存储过程时,如果执行期间出现异常,或者在存储过程抛出异常,系统就会把异常提示信息与抛出异常信息提示给用户。页面装载前可以填写一个为表单初试化的一个脚本,比如预先把一些值放入文本主从表里。页面装载后同上保存前做一些业务逻辑的检查,不符合条件不让其保存。保存后执行相关的业务操作,比如把数据copy到其它的数据表中。5字段扩展设置字段的扩展设置是高级应用,如下图:5.0 表单装载前数据填充需求背景:我们知道一个表单的数据包含四种模式,主表数据、从表数据(可多个)、一对多的数据(可多个)、还有一些附件与图片数据(可多个)。在一个表单被加载前用户往往要为这个表单初始化一些数据。比如发起一个请假流程,用户进入请假流程表单时,想把该用户主表数据比如电话、邮件、部门、部门负责人信息(主表数据),请假的历史数据(从表)都要初始化出来。在比如:已知一个订单号在发起流程前要把该用户的客户基本信息(主表)与订购清单(从表)预先填充表单并显示出来。这样的示例会很多,当然可以利用表单事件来完成,但是书写那个存储过程太麻烦,为了解决这个问题,现在抽象出来这种应用模式,以方便各位使用。设置方式: 表单设计器-扩展设置=特别说明: 从表也是从表,应该为只读,才符合正常的逻辑,如果非只读也不能保存它。5.1数据获取什么是数据自动获取?当一个字段的值是从其它表中取出来,或者通过后台的计算出来,或者通过js脚本计算出来,我们称为字段的数据自动获取。自由表单的获取方式分为,保存后获取与js计算获取两种方式。自动获取分为如下几种方式:方式1:本表单中数据计算1, 表单中的字段计算分为主表字段之间的计算与从表之间的计算,它们的设置格式与约定规则都是相同的。如果设置的是表单的主表字段,那么是表单上主表控件值之间的计算了。如果设置的是从表的字段,那么就是表单列这间的计算。2, 表达公式支持中文也支持字段名称,比如:你可以书写成 单价*金额 也可以书写成danjia*jiner3, 计算是以javascript 方式完成的。所以当数值变化后就可以看到计算结果。方式2:利用SQL自动填充.比如: Select Addr From 商品表 WHERE No=FK_Pro FK_Pro是本表中的任意字段名。应用案例:在请假流程表单中获取两个表单日期(开始日期,结束日期)的相隔的天数。处理步骤:1, 首先在建立一个函数 GetSpanDays(dtForm,dtTo) 。 dtFrom,日期从,dtTo 日期到。2, 设置一个SQL,放在文本框里。 For sqlserver: SELECT GetSpanDays(DTForm,DTTo) For Orace : SELECT GetSpanDays(DTForm,DTTo) FROM DUAL3, 把此字段设置为只读(只有只读的字段才可以被自动计算)。工作原理:CCForm在保存后,首先检查一个只读字段是否有扩展属性,如果有就把设置的信息SQL中的变量替换下来,执行这个SQL,把返回值赋给当前这个只读字段。方式3:本表单中外键列。比如:表单中有商品编号列,需要填充商品地址、供应商电话。方式4:对一个从表的列求值。对于有从表的有效,在案例视频中有一个报销总金额=从表的小计中求合。总结:对于3,4两种模式都可以变相的用第二种模式实现它。5.2级联下拉框主表中的级联在表单中级联下拉框经常用到,下面是一个典型的事例。我们分析一下,地区与省份是关联的,省份与城市是关联的。这样的业务规则我们可以抽象出来两两关联,就可以解决了无限级关联的问题。配置步骤如下:第一步:配置片区与省份的关联。在片区控件上点右键编辑它=扩展属性。点编辑进入下一步骤。点扩展设置进入下一步骤。点新建通过sql方式联动子下拉框,也就是片区联动省份。重复上一步骤,让片区省份联动城市。 无限级的下拉框的联动,就可以制作成功了。从表中的级联从表的级联与主表的级连设置方式一样的。上面是效果图。常见问题1, 在从表中设置级联:没有正常设置下拉框的默认值,导致整个页面被保存。例如:省份设置默认为山东,城市设置默认为北京,这样就会造成全页面的从表存盘问题。2, 待续。5.3表单字段的输入js脚本验证标题:表单字段输入验证.关键字: 表单设计器, 字段验证. workflow,ccform, ccflow.说明:对控件的用户输入采取输入控制,与输入后的校验。比如校验是否是e-mail, 是否是手机号,身份证号等等。设置步骤操作路径:字段属性, 扩展设置,脚本验证。字段列表:验证邮政编码设置:函数库分为:系统函数库,与我自己定义的函数库。系统函数库是ccflow系统自带的函数库,它包括一些基本的,通用类型的验证,比如:电话、邮件、邮政编码。如果验证需要特殊的验证,那就需要自定义函数库了,如何定义个性化的函数请参考下一章节。点保存按钮就可以了,系统将会自动返回字段列表。这样的一个脚本验证就完成了,把它非常方便了为用户的输入完成了验证设置。如何设置自定义验证函数?按照如下步骤设置:1, 建立一个js脚本文件。2, 根据此脚本文件的事件,D:ccflowVisualFlowDataUserJSLib 对应的文件目录里。比如 :onblur 事件函数放在onblur目录里,onkeypress事件函数放在onkeypress目录里。3, 函数名必须为小写,事例如下:function isMobil(ctrl) var patrn = /+0,1(d)1,3 ?(-?(d)| )1,12)+$/; if (!patrn.exec(ctrl.value) alert('非法的手机号码.'); return false; return true脚本验证的工作原理系统函数的目录为:D:ccflowVisualFlowDataJSLib用户自定义的函数目录为:D:ccflowVisualFlowDataUserJSLib表单设计器自动产生的脚本文件位与D:ccflowVisualFlowDataUserJSLibData在你执行保存时,表单设计器就把所有的函数调取出来,生成一个脚本验证文件,此文件命名的格式为。 表单编号+”.js” 。 并存放在: D:ccflowVisualFlowDataUserJSLibData 目录下面。表单载入时,就把此脚本文件自动的调入到界面上。如何通过获取表单控件值(使用ccform内置函数)?我们知道在ccform表单设计器中有4种控件分别是dropdownlistbox, textbox,checkbox,ridionbutton.系统内置了三个函数,分别是获取相应对象的值,请参考以上图片。ReqTB 获取TextBox类型字段的输入值。ReqDDL 获取DropDownListbox的选择值。ReqCB 获取CheckBox的值。如何在提交前做一个完整的表单输入验证?关键字: ccform 字段验证 工作流程引擎 提交前输入完整性验证设置步骤:1, 建立一个自定义的js文件,放在D:ccflowVisualFlowDataUserJSLibData下面。2, 命名格式为表单ID+”_Self.js”。比如:ND1701_Self.js3, 在自定义js文件(ND1701_Self.js)中创建一个一个校验函数。3, 打开该节点属性=找到功能按钮标签与状态=发送按钮标签=按钮js函数文本框中填写: return IsSubmit();5.4自动完成自动完成包括三大部分,主表中的自动完成,主从表的自动完成,从表中的自动完成。5.4.1 演示环境说明5.4.2主表中的自动完成以如下图应用为例,来说明:上图是用傻瓜表单设计器设计的,但是对自由表单设计器一样有效。用户操作希望输入合同编号后,能够把客户名称,广告内容,业务员,广告类别自动的填写上。在合同号的控件中,输入合同编号希望有自动完成效果,其它几个控件是只读的。在输入合同号后,自动填写其它的数据内容。我们看看运行的效果:配置步骤:打开表单设计器-找到合同号字段-编辑属性-扩展设置-自动完成。我们把复制出来的sql内容显示如下:SELECT TOP 10 htjb_htbh as No, isnull(htjb_khmc , htjb_ggnr) as Name, htjb_ggnr as guanggaoneirong , htjb_khmc as kehumingcheng, isnull(htjb_ywy, '未填写' ) as yewuyuan, isnull(htjb_ggxs, '未填写' ) as guanggaoleibie FROM dbname.dbo.guanggao_htjbxx WHERE htjb_htbh LIKE 'Key%' 这个sql是一个结果集合:它必须有No,Name 两个列,这两个列是用来控制显示在自动填写的下拉框中。其它的列名需要与主表的字段对应上才能自动填充上去。5.4.2主从表的自动完成在上一节中我们讲到了主表的自动完成,现我在们讲主从表的自动完成。以以下通用需求为例来说明:一个合同号跟着几个广告线路,在输入合同号后,主表的信息管理输出出来后,还要把从表的线路信息关联出来。这样的业务规则称为主从表的业务关联。5.4.3从表中的自动完成在从表中如果输入了线路名称需要把线路的其它信息在从表中反映出来。这里有两种业务规则模式:1, 一条从表记录对外键范围无要求的。比如:输入一个合同编号,把合同名称,客户名称,客户地址,合同类型都显示这一个行的其它控件上。配置方式同主表的配置方式。2, 一条记录对于外键字段的范围有要求。仍然以以上业务规则为例:一个公交公司有n多车类型,有一个表存放公交车类型。一个线路的公交车类型是有范围的,就是公交车类型表的一个子集。如上效果图:当我输入个线路时,回车后系统就会把该线路下的车型过滤出来。配置方式:第一步:设置线路下拉框的自动完成。 第二步:点保存右边的 级联下拉框 连接,为车型下拉框设置过滤sql。 5.5 字段超连接字段超连接是把只读的并且是可见的字段不以控件方式显示,而是用户超连