`
ribishuangba
  • 浏览: 290855 次
文章分类
社区版块
存档分类
最新评论

ice:selectOneMenu应用

 
阅读更多

ice:selectOneMenu是一个下拉框列表,可以单选一个值。这个tag还是有点复杂,官方文档也不是很仔细,浪费了我不少时间。下面是例子代码:


配合f:selectItem,我们可以静态的提供下拉列表中的候选值。这里要注意的是,valueChangeListener事件的处罚必须要加上partialSubmit="true"这个条件。这是文档中没有描述的。immediate="true"是无效的。
现在我们看看动态产生下拉列表值的例子:

这里TestBean.values对应的是SelectItem[],代码如下:
public class TestBean {

/** Creates a new instance of TestBean */
public TestBean() {
values=new SelectItem[2];
values[0]=new SelectItem();
values[0].setLabel("A1");
values[0].setValue(1);
values[1]=new SelectItem();
values[1].setLabel("A2");
values[1].setValue(2);
}

private SelectItem[] values;

/**
* @return the values
*/
public SelectItem[] getValues() {
return values;
}

...

在我的其他应用程序中,List也是可以使用的,但是很奇怪,在这个测试工程里总是报错。姑且认为是icefaces1.8.1的一个bug吧。


总是要使用partialSubmit="true"才能让ValueChangeEvent事件生效,在某些场合是有限制的。比如,如果你在前面增加一个ice:inputText来输入姓名,不要指望在ValueChangeEvent事件处理函数中得到这个值,因为部分提交是不会将Form中的其他值提交到服务端的。解决方案有两个,一个是在新增的ice:inputText中也应用partialSubmit="true"属性,这样当输入完毕,焦点从ice:inputText中移出的时候,setXX方法就可以被调用,然后ValueChangeEvent事件处理函数就可以使用输入值。还有一种方案就是增加javaScript调用,造成整个form提交。下面是第一种方法的代码:



public void changeValue(ValueChangeEvent event){
result=name;
}

private String name;

/**
* @return the name
*/
public String getName() {
return name;
}

/**
* @param name the name to set
*/
public void setName(String name) {
this.name = name;
}

private String result;

/**
* @return the result
*/
public String getResult() {
return result;
}

/**
* @param result the result to set
*/
public void setResult(String result) {
this.result = result;
}













分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics