У меня есть простой пример составного компонента JSF 2.0.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xmlns:cc="http://java.sun.com/jsf/composite" xmlns:ui="http://java.sun.com/jsf/facelets" xmlns:h="http://java.sun.com/jsf/html" xmlns:f="http://java.sun.com/jsf/core"> <head> <title> A panel box component </title> </head> <body> <cc:interface> <cc:attribute name="model" required="true" type="at.test.Person"/> </cc:interface> <cc:implementation> <h:inputText value="#{model.vorname}"> </h:inputText> </cc:implementation> </body>
А вот моя тестовая страница JSF:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xmlns:ui="http://java.sun.com/jsf/facelets" xmlns:h="http://java.sun.com/jsf/html" xmlns:f="http://java.sun.com/jsf/core" xmlns:mc="http://java.sun.com/jsf/composite/mygourmet" > <h:body> <h:form> <mc:inputTest model="#{person}"> </mc:inputTest> <h:commandButton value=""/> <h:outputText value="#{person.vorname}"/> </h:form> </h:body> </html>
Я хочу, чтобы мой составной компонент сохранял строковое значение в сессионном компоненте JSF с <h:inputText>.Но проблема в том, что когда я отправляю форму с <h:commandButton>, я вижу следующую ошибку:
<h:inputText>
<h:commandButton>
Caused by: javax.el.PropertyNotFoundException: /resources/mygourmet/inputTest.xhtml at line 18 and column 42 value="#{model.vorname}": Target Unreachable, identifier 'model' resolved to null at org.apache.myfaces.view.facelets.el.TagValueExpression.getType(TagValueExpression.java:73) at org.apache.myfaces.shared_impl.renderkit._SharedRendererUtils.findUIOutputConverter(_SharedRendererUtils.java:77)
Вам необходимо ссылаться на значения атрибутов составного компонента по #{cc.attrs.<name>}, где <name> - это имя атрибута. Итак, это должно сделать:
#{cc.attrs.<name>}
<name>
<h:inputText value="#{cc.attrs.model.vorname}">
<composite:xxx>
Не связано с конкретной проблемой, все, что <html><head><body> в композите, не нужно. Я предлагаю использовать <ui:component>, так как это более понятно. См. Также нашу вики-страницу составного компонента для примеров.
<html><head><body>
<ui:component>