我需要使用 jsf 2.0 自定义组件动态创建面板。面板内的控件将从 xml 中动态读取并在选择相应对象时呈现(例如:如果选择了 Person,我应该呈现一个面板,该面板将具有与人相关的控件,例如:Person age field(inputtext),人 DOB(日历)等)。
我试图从扩展 UIComponentBase 的组件类中呈现它。
ResponseWriter writer = Util.getResponseWriter(context);
//start the <table> tag
writer.startElement(Constants.STR_TABLE, this);
//start the <tr> tag
writer.startElement(Constants.STR_TR, this);
//start the <td> tag
writer.startElement(Constants.STR_TD, this);
//encode the button 1 component inside this <td>
encodeAllComponent(context, getMyPrimePanel());
// end the <td> tag
writer.endElement(Constants.STR_TD);
//end the <tr> tag
writer.endElement(Constants.STR_TR);
//end the <table> tag
writer.endElement(Constants.STR_TABLE);
//private variable to render a panel
private Panel myPrimePanel;
/**
* @return the myPrimePanel
*/
public Panel getMyPrimePanel() {
System.out.println("inside the panel get method------");
if (myPrimePanel.getChildCount() <= 1) {
System.out.println("inside the panel creation function");
InputText input = new InputText();
myPrimePanel.getChildren().add(input);
}
System.out.println("inside the panel get method-------------");
return myPrimePanel;
}
/**
* @param myPrimePanel the myPrimePanel to set
*/
public void setMyPrimePanel(Panel myPrimePanel) {
System.out.println("inside the panel get method-------------");
//initialize the button 1 component
this.myPrimePanel = myPrimePanel;
}
我是这样做的。但是我得到一个空指针异常。如何动态呈现具有已定义控件的面板?
这就是我得到的 -
====将开始渲染==== 面板内获取方法------ 2011 年 9 月 7 日上午 10:01:42 com.sun.faces.context.PartialViewContextImpl$PhaseAwareVisitCallback 访问 严重:java.lang.NullPointerException
最佳答案
myPrimePanel
为空。您需要为其分配一个实例,以使其不为空。
但是,我认为您以错误的方式执行此任务。您不应该在渲染阶段向树中添加组件。据推测,您希望在某个时候读取、验证数据并将其输入到模型中。
在 encodeBegin 中发出你的开始元素.在 encodeEnd 中发出你的结束元素.不要覆盖 encodeChildren并确保 getRendersChildren返回 false(这是默认值)。
使用绑定(bind)属性在恢复 View 阶段提供动态组件。添加一个属性类型为 UIComponent 的请求范围托管 bean并使用 EL 将它绑定(bind)到 View 中的元素。在 getter 中,如果该属性为 null,则创建自定义控件的新实例并添加任何 children .
考虑这个观点:
<h:form>
<h:panelGroup id="myPanel" binding="#{componentMakerBean.panel}" />
<h:commandButton value="go" action="#{componentMakerBean.dumpValuesAction}" />
</h:form>
面板是在 bean 中创建和填充的:
/** Request scope bean defined in faces-config.xml */
public class ComponentMakerBean {
private UIPanel panel;
public UIPanel getPanel() {
if(panel == null) {
panel = new HtmlPanelGroup();
for(int i=0; i<3; i++) {
panel.getChildren().add(new HtmlInputText());
}
}
return panel;
}
public void setPanel(UIPanel panel) { this.panel = panel; }
public String dumpValuesAction() {
for(Object kid : panel.getChildren()) {
if(kid instanceof ValueHolder) {
ValueHolder valueHolder = (ValueHolder) kid;
System.out.println(valueHolder.getValue());
}
}
return null; //no navigation
}
}
在运行时,这将发出三个可编辑的文本字段,其值将在单击按钮时打印到日志中。
此代码已在使用 Java 5 和 JSF 1.1 的 JSP 中进行测试。
关于java - 关于 JSF 2.0 自定义组件和 Primefaces 的帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7329070/