af:selectManyChoice 是一个下拉多选框,如下图:
这个组件使用起来不是那么容易,它需要将表单中的一个column的attribute 和 组件中的selectitems之间互相转换。
正好今天有个客户问起,兴致所致就写了简单的例子,下载。
我不详细展开讲了,简要描述下:
1) af:selectManyChoice 的value attribute 绑定到一个managed bean的get和set 方法上
2) af:selectManyChoice的autosumit=true, immediate=true
3) 可选择值为一个Static List的View Object, 在页面的binding中配置该lov,并且在selectItems的value属性绑定到该lov。
4)在af:selectManyChoice 的value对应的manage bean的get/set方法中,将页面选择的index对应到lov的具体值并存放到数据库,读取则反之。
下载包的密码是: gene.xujin@gmail.com
在ADF页面上有两种EL的引用af:tree,af:treeTable,af:table的数据集合的方式。一种是#{row.attributeName},另一种是#{row.bindings.attributeName.inputValue}。 这两者的区别是:前者是只读的 而后者是可读写的。前者这是将该属性以字符串的形式返回,该EL的返回值是一个String类型,后者则不同,#{row.bindings.attributeName}是一个Attribute Binding, 在运行时是一个FacesCtrlAttrsBinding 类的实例,该类是框架内部使用的类,继承了JUCtrlAttrsBinding。所以只要表格需要更新,就应该使用{row.bindings.attributeName.inputValue},另外一个例子是#{node.attributeName},node表示了树组件中的一个节点,可以对应到table组件的row。
ADF具有一个非常健壮的验证框架。表单验证可以在各个层次上进行(view, model和business service)。如果需要详细研究验证机制,请参考Fusion Developer's Guide for Oracle Application Development Framework.
在现实的开发过程中,经常有一些页面需要暂时的跳过默认的验证,本文旨在讨论下常见的use case:
1. Keep immediate=true
一个最常用的方式就是将UICOMPONENT的immediate属性设置为true,这样可以将对组件的处理提前到Apply Request Values阶段。关于immediate属性可以参考 wiki
典型用例:cancel button,在取消按钮点击时,页面是不需要验证提交的表单的。可以将按钮组建的immediate属性设为'true'来实现这个功能。 如果是一个reset按钮,那么除了immediate属性需要设为'true‘外,最好还要调用下相关其他input组件的resetValue()方法,来恢复初始状态。
2. SkipValidation
另外一种方式,是设置pagedefinition 文件的SkipValidation 属性。该属性可以控制跳过model层的验证。需要注意的是,这个属性只对entity level的validation rule起作用,对于entity object的attribute上定义的validation rule是没有作用的。另外对于浏览器端的验证(javascript),这个属性也是没法控制的。
这个属性可以在每个页面对应的Page Definition 文件中找到,如下图:
这个属性可能有的值,见下图:
a. SkipValidation=true
设为true则在form提交过程中会跳过Model层的验证,直到commit的时候才会进行验证。
典型场景:如需要在一张表中输入很多行信息,用户可能希望可以在页面中以任何顺序输入信息,不希望每次table selection事件都会触发验证。
b. SkipValidation=custom
设为custom的时候,需要开发人员实现一个oracle.binding.BindingContainerValidator的接口的类,并用EL配置,如图:
这个选择项给了开发人员更多的空间来应对复杂的业务需求,开发人员可以自定义如何对表单进行验证。
c. SkipValidation = skipDataControls
skipDataControls 选择项的意思是会跳过data control这个level的验证,或者说是事务级别的验证。它只会对当前的binding container中的iterator的current row进行验证,而不会对其他不相关的提交的数据进行验证。
典型场景: 在一个页面上使用了多个data control,提交一个data control不会验证同一个页面中的其他data control中的数据。
d. SkipValidation=false
默认值,不会跳过验证。
摘要: 在af|inputDate 组件上防止键盘输入 gene 有些情况下,我们会需要日期输入控件不允许用户用键盘输入日期。要实现这样的功能就需要使用到Javascript。功能的效果如下图: Javascript:?12<af:resource> function disableEntry(evt){ evt.cancel(); }</af:resour...
阅读全文
在删除某几条数数据的时候,可以用多选项选中多条记录,再点击删除按钮的时候需要做一下判断是否确认删除,如果一条记录都没有删除,那么就不弹出确认的对话框。
<script>
function CheckAll(srcElem, do_check){
if(typeof(srcElem)=='undefined') return;
var cnt = (typeof(srcElem.length)!='undefined')? srcElem.length : 0;
if(cnt){
for(var i=0;i<cnt; i++)
srcElem[i].checked = do_check;
}else
srcElem.checked = do_check;
}
function deleteYN(){
//if(YN(this.form.elements['delBox'], this.checked)){if(!confirm('确实要删除吗?')) return false;}else return false;
if(typeof(form1.elements['delBox'])=='undefined'){
return false;
}else{
if(form1.delBox.checked==true){
if(!confirm('确实要删除吗?'))
return false;
else
return true;
}else{
for(var i=0;i<form1.delBox.length; i++){
if(form1.delBox[i].checked==true){
if(!confirm('确实要删除吗?'))
return false;
else
return true;
}
}
}
return false;
}
return false;
}
</script>
<input type="submit" name="delSubmit" value="删除" onClick="return YN();" >
<input type="checkbox" name="alcheck" value="0" title="点击全选或者全不选" onclick="CheckAll(this.form.elements['delBox'], this.checked)" >