usable range
process
cms
example
//可以在脚本中获取该组件
//方法1:
var address = this.form.get("name"); //获取组件
//方法2
var address = this.target; //组件本身的事件和脚本中获取
source
members
descriptionnodeelement
描述信息节点,允许用户手工输入的组件才有此节点,只读情况下无此节点.
type
-
element
inherited from
source
nodeelement
组件的节点,mootools封装过的dom对象,可以直接使用原生的js和moootools方法访问和操作该对象。
type
-
element
example
//可以在脚本中获取该组件
var field = this.form.get("fieldid"); //获取组件对象
field.node.setstyle("font-size","12px"); //给节点设置样式
source
jsonjsonobject
组件的配置信息,比如id,类型,是否只读等等。可以在组件的queryload事件里修改该配置来对组件做一些改变。
type
-
jsonobject
example
//可以在脚本中获取该组件
var json = this.form.get("fieldid").json; //获取组件对象
var id = json.id; //获取组件的id
var type = json.type; //获取组件的类型,如textfield 为文本输入组件,select为下拉组件
//在组件queryload事件里设置组件只读。
//当前组件的queryload事件运行时还没有在form里注册,通过this.form.get("fieldid")不能获取到当前组件,需要用this.target获取。
var json = this.target.json;
json.isreadonly = true; //设置组件为只读。
source
formmwf.xapplication.process.xform.form
组件的所在表单对象.
type
example
var form = this.form.get("fieldid").form; //获取组件所在表单对象
var container = form.container; //获取表单容器
source
parentlinemwf.xapplication.process.xform.datatemplate.line|mwf.xapplication.process.xform.datatablepc.line|mwf.xapplication.process.xform.datatablemobile.line
当前组件在数据表格或者数据模板中时,可以通过此属性获取所在行(条目)对象.
type
-
mwf.xapplication.process.xform.datatemplate.line
|mwf.xapplication.process.xform.datatablepc.line
|mwf.xapplication.process.xform.datatablemobile.line
inherited from
example
//获取当前组件所在数据模板/数据表格的行(条目)对象
var line = this.target.parentline;
//获取当前字段所在行下标
var index = line.getindex();
//获取当前字段所在条目的subject字段的值
var data = line.getmodule("subject").getdata();
//设置当前字段所在条目的subject字段的值
line.getmodule("subject").setdata("test1");
source
methods
reload()
summary
重新加载组件。会执行postload事件。
inherited from
example
this.form.get("fieldid").reload(); //重新加载事件
source
getoptions() → {array|promise}
summary
获取选择项。
inherited from
returns
-
array
promise
返回选择项数组或promise,如:
[ "女|female", "男|male" ]
examples
this.form.get('fieldid').getoptions();
//异步
var opt = this.form.get('fieldid').getoptions();
promise.resolve(opt).then(function(options){
//options为选择项数组
})
source
setdata(value)
summary
为组件赋值。
description
当表单上没有对应组件的时候,可以使用this.data[fieldid] = data赋值。
parameters
-
value
string
.
inherited from
examples
this.form.get("fieldid").setdata("test"); //赋文本值
//如果无法确定表单上是否有组件,需要判断
if( this.form.get('fieldid') ){ //判断表单是否有无对应组件
this.form.get('fieldid').setdata( data );
}else{
this.data['fieldid'] = data;
}
source
resetoption(callback)
summary
重新计算下拉选项.
parameters
-
callback
function
回调方法
inherited from
examples
this.form.get('fieldid').resetoption();
this.form.get('fieldid').resetoption(function(){
//设置完成后的回调
});
source
addoption(text, value)
summary
添加下拉选项.
parameters
-
text
string
下拉选项文本
-
value
string
下拉选项值
inherited from
example
this.form.get('fieldid').addoption("秘密","level1");
source
gettext() → {array|promise}
summary
获取选中项的text。
inherited from
returns
-
array
promise
返回选中项的text
examples
var text = this.form.get('fieldid').gettext(); //获取选中项的文本
//如果选项是异步的,比如数据字典、视图、查询视图
var p = this.form.get('fieldid').gettext(); //获取选中项promise
promise.resolve(p).then(function(text){
//text 为选选中项的文本
})
source
gettextdata() → {object|promise}
summary
获取选中的值和文本.
inherited from
returns
-
object
promise
返回选中项值和文本,格式为 { 'value' : [value], 'text' : [text] }.
examples
var array = this.form.get('fieldid').gettextdata();
//异步
var array = this.form.get('fieldid').gettextdata();
promise.resolve(array).then(function(arr){
//arr为选中项值和文本
})
source
getoptionsobj(refreshopt) → {object}
summary
获取整理后的选择项。
parameters
-
refresh
boolean
是否忽略缓存重新计算可选项。
inherited from
returns
-
object
返回整理后的选择项数组或promise,如:
{"valuelist": ["","female","male"], "textlist": ["","女","男"]}
examples
var optiondata = this.form.get('fieldid').getoptionsobj();
//异步
var opt = this.form.get('fieldid').getoptionsobj(true);
promise.resolve(opt).then(function(optiondata){
//optiondata为选择项
})
source
isreadonly() → {boolean}
summary
判断组件是否只读.
inherited from
returns
-
boolean
是否只读.
example
var readonly = this.form.get('subject').isreadonly();
source
isempty() → {boolean}
summary
判断组件值是否为空.
inherited from
returns
-
boolean
值是否为空.
example
if( this.form.get('subject').isempty() ){
this.form.notice('标题不能为空', 'warn');
}
source
getdata()
summary
获取组件值。
description
在脚本中使用 this.data[fieldid] 也可以获取组件值。
区别如下:
1、当使用promise的时候
使用异步函数生成器(promise)为组件赋值的时候,用getdata方法立即获取数据,可能返回修改前的值,当promise执行完成以后,会返回修改后的值。
this.data[fieldid] 立即获取数据,可能获取到异步函数生成器,当promise执行完成以后,会返回修改后的值。
2、当表单上没有对应组件的时候,可以使用this.data[fieldid]获取值,但是this.form.get('fieldid')无法获取到组件。
inherited from
returns
-
组件的数据.
examples
var data = this.form.get('fieldid').getdata(); //没有使用promise的情况、
//如果无法确定表单上是否有组件,需要判断
var data;
if( this.form.get('fieldid') ){ //判断表单是否有无对应组件
data = this.form.get('fieldid').getdata();
}else{
data = this.data['fieldid']; //直接从数据中获取字段值
}
//使用promise的情况
var field = this.form.get("fieldid");
var dict = new this.dict("test"); //test为数据字典名称
var promise = dict.get("tools", true); //异步使用数据字典的get方法时返回promise,参数true表示异步
promise.then( function(){
var data = field.getdata(); //此时由于异步请求已经执行完毕,getdata方法获取到了数据字典的值
})
field.setdata( promise );
source
validate(routenameopt) → {boolean}
summary
根据组件的校验设置进行校验。
parameters
-
routename
string
可选,路由名称.
inherited from
returns
-
boolean
是否通过校验
example
if( !this.form.get('fieldid').validate() ){
return false;
}
source
getsource(typeopt) → {source|subsource|subsourceitem}
当前组件在数据源组件中时,可以通过此方法获取所在的上级数据源/子数据源/子数项组件.
parameters
-
type
string
需要获取的类型,"source"为表示数据源,"subsource"表示子数据源,"subsourceitem"表示子数据项组件。 如果该参数省略,则获取离当前组件最近的上述组件。
inherited from
returns
-
source
subsource
subsourceitem
。
example
var source = this.target.getsource(); //获取当前组件的所在子上级数据源/子数据源/子数项组件.
var data = source.data; //获取数据
var source = this.form.get("fieldid").getsource("source"); //获取数据源组件
var data = source.data; //获取数据
source
getparentmodule(typeopt, validatefunctionopt) → {mwf.xapplication.process.xform.$module}
获取当前组件所在的祖先组件.
parameters
-
type
string
需要获取的组件类型。 如果该参数省略,则获取离当前组件最近的祖先组件。type有效值如下:
form- 表单common- 通用组件datatable- 数据表格datatableline- 数据表格行datatemplate- 数据模板datatemplateline- 数据模板行div- 容器组件elcommon- element通用组件elcontainer- element容器组件subform- 子表单source- 数据源组件subsource- 子数据源subsourceitem- 子数据项组件tab- 分页组件tabpage- 分页组件的某个分页table- 表格tabletd- 单元格widget- 部件 -
validatefunction
function
进一步校验,参数为获取到匹配到类型的组件,返回false继续往上取对应类型的组件,返回true返回该组件。
inherited from
returns
example
var module = this.target.getparentmodule(); //获取最近的祖先。
var datatemplateline = this.target.getparentmodule("datatemplateline"); //获取当前组件所在的数据模板行.
var module = this.target.getparentmodule(null, function(module){
return module.json.id === "div_1";
}); //获取当前组件id为div_1的父组件。
source
hide()
summary
隐藏组件.
inherited from
example
this.form.get("fieldid").hide(); //隐藏组件
source
show()
summary
显示组件.
inherited from
example
this.form.get("fieldid").show(); //显示组件
source
events
commitinput
手工输入完成后触发。
change
值改变时触发。
load
组件加载后触发。如果选项加载为异步,则异步处理完成后触发此事件
queryload
组件加载前触发。queryload执行的时候,当前组件没有在form里注册,通过this.form.get("fieldid")不能获取到当前组件,需要用this.target获取。
postload
组件加载后触发.