表单、字段属性、事件
表单属性
前端进入表单V8事件
- 可以做一些默认值处理
js
//如果是新增数据
if(V8.FormMode == 'Add'){//FormMode可能的值:Add(新增)、Edit(编辑)、View(预览)
V8.FormSe('Name', V8.CurrentUser.Name);//设置默认值
}前端提交表单前V8事件
- 可以做一些表单验证,提升用户体验
js
//若代码出现return Code为0时,则会在前端阻止表单继续提交
return { Code : 0, Msg : '错误信息,已阻止表单提交!' };
//表单提交类型,可能的值:Insert、Update、Delete
var submitType = V8.FormSubmitAction;前端离开表单后V8事件
- 一般建议使用【服务器端表单提交后V8事件】
- 此事件可以做一些特殊业务逻辑处理
服务器端数据处理V8事件
- 该事件会在获取列表数据后每一行执行、获取表单数据后执行。
- 已封装对象:
- a)V8.RowIndex:列表数据的行索引,0开始
- b)V8.Form:列表数据每行对象、表单数据对象
- c)V8.NotSaveField:指定哪些字段在编辑时不保存
- d)V8.CacheData:用于缓存数据
- 可以实现某些字段脱敏,如:V8.Form.价格 = "";此时一定要设置:V8.NotSaveField = ["价格"];否则在修改数据时会将写到数据库。
- 示例:
javascript
//如果不是超级管理员,数据脱敏
if(V8.CurrentUser.Level < 999){
V8.Form.Price = "***";//脱敏
V8.Form.CompanyName = "***";//脱敏
V8.NotSaveField = ["Price", "CompanyName"];//告诉前端,此字段在编辑时不保存
}服务器端表单提交前V8事件
- 此事件在事务中执行
js
//表单提交类型,可能的值:Insert、Update、Delete
var submitType = V8.FormSubmitAction;
//若代码出现return,并且未指定Code的值、或Code值不等于1时,则会在后端阻止表单继续提交,并且自动回滚事务,无需手动执行V8.DbTrans.Rollback()
return { Code : 0, Msg : '错误信息,已阻止表单提交!' };
//若代码出现return,并且未指定Code的值,则会在后端阻止表单继续提交,并且自动回滚事务,无需手动执行V8.DbTrans.Rollback()
return { A : 111, B : 222 };
//此时增删改接口会返回数据格式:
{ Code : 0, Data : { A : 111, B : 222 }, Msg : "执行[表单提交前V8事件]失败,V8事件返回结果:{ A : 111, B : 222 }" }
//在事务中操作其它表
var result = V8.FormEngine.UptFormData('other_table', {
_Where:[]
}, V8.DbTrans);
if(result.Code != 1){
//此时可无需执行V8.DbTrans.Rollback()回滚事务,平台会自动回滚事务
return { Code : 0, Msg : 'other_table修改失败,已阻止表单提交!已回滚事务!' };
}
//执行其它接口引擎时,可选传入V8.DbTrans对象。此时一般此接口内部也无需手动提交或回滚事务。
result = V8.ApiEngine.Run('apiengine_key', {
Form : V8.Form//传入当前表单数据
}, V8.DbTrans);
//防止某些接口引擎未返回数据,而是返回的null导致result.Code报错,所以这里的判断是【result && result.Code != 1】
if(result && result.Code != 1){
return result;//平台会自动回滚事务,无需手动执行V8.DbTrans.Rollback();
}服务器端表单提交后V8事件
- 此事件仍在事务中执行,如果要获取当前表单提交后的数据,需要使用V8.DbTrans对象来获取
js
//若代码出现return,并且未指定Code的值、或Code值不等于1时,则会在后端阻止表单继续提交,并且自动回滚事务,无需手动执行V8.DbTrans.Rollback()
return { Code : 0, Msg : '错误信息,已阻止表单提交!' };
//若代码出现return,并且未指定Code的值,则会在后端阻止表单继续提交,并且自动回滚事务,无需手动执行V8.DbTrans.Rollback()
return { A : 111, B : 222 };
//此时增删改接口会返回数据格式:
{ Code : 0, Data : { A : 111, B : 222 }, Msg : "执行[表单提交后V8事件]失败,V8事件返回结果:{ A : 111, B : 222 }" }
//在事务中操作其它表
var result = V8.FormEngine.UptFormData('other_table', {
_Where:[]
}, V8.DbTrans);
if(result.Code != 1){
//此时可无需执行V8.DbTrans.Rollback()回滚事务,平台会自动回滚事务
return { Code : 0, Msg : 'other_table修改失败,已阻止表单提交!已回滚事务!' };
}
//在事务中获取当前数据。也可以使用V8.Form访问前端传入的当前数据,但可能数据字段并不完整
result = V8.FormEngine.GetFormData('this_table', {
Id : V8.Form.Id
}, V8.DbTrans);//若不传入V8.DbTrans对象,则在修改、删除事件中获取的是老数据。而在新增事件中获取不到数据,因为事务还未提交。
//表单提交类型,可能的值:Insert、Update、Delete
var submitType = V8.FormSubmitAction;
//执行其它接口引擎时,可选传入V8.DbTrans对象。此时一般此接口内部也无需手动提交或回滚事务。
result = V8.ApiEngine.Run('apiengine_key', {
Form : V8.Form
}, V8.DbTrans);
//防止某些接口引擎未返回数据,而是返回的null导致result.Code报错,所以这里的判断是【result && result.Code != 1】
if(result && result.Code != 1){
return result;//平台会自动回滚事务,无需手动执行V8.DbTrans.Rollback();
}字段属性
绑定角色
- 当字段绑定了角色时,只有该角色在查看表单时才能看到此字段