based on previous question how id of calling component in getter method? , here's idea want ask opinion :
there lots of duplicated code across jsf pages such these examples (notice repeating size , maxlength attribute) across components :
<h:inputtext label="#{msgs.userid}" id="userid" value="#{userbean.userid}" required="true" size="#{variableconfigbean.getsize(component.id)}" maxlength="#{variableconfigbean.getmaxlength(component.id)}" /> <h:inputsecret label="#{msgs.password}" id="password" value="#{userbean.password}" required="true" size="#{variableconfigbean.getsize(component.id)}" maxlength="#{variableconfigbean.getmaxlength(component.id)}" />
im thinking of :
- using composite component input text tag,
- hardcoding size , maxlength in implementation section of composite component,
- so dont have duplicate these stuffs everytime need use component.
- but i'll have open attributes in interface section of composite component
is idea ok, or perhaps there other better ways solve problem ?
you so. i've implemented in projects. adds (minor) overhead. particular purpose use facelets tag file instead of jsf composite component. it's not mandatory define attributes then. in particular case can refactor pretty duplicates if reuse bean property name id , key message bundle label.
e.g.
<my:input type="text" bean="#{userbean}" property="userid" required="true" /> <my:input type="secret" bean="#{userbean}" property="password" required="true" />
with following in facelets tag file:
<c:set var="id" value="#{not empty id ? id : property}" /> <c:set var="required" value="#{not empty required , required}" /> <c:choose> <c:when test="#{type == 'text'}"> <h:inputtext id="#{id}" label="#{msgs[property]}" value="#{bean[property]}" size="#{config.size(id)}" maxlength="#{config.maxlength(id)}" required="#{required}" /> </c:when> <c:when test="#{type == 'secret'}"> <h:inputsecret id="#{id}" label="#{msgs[property]}" value="#{bean[property]}" size="#{config.size(id)}" maxlength="#{config.maxlength(id)}" required="#{required}" /> </c:when> <c:otherwise> <h:outputtext value="unknown input type: #{type}" /> </c:otherwise> </c:choose>
i've implemented <h:outputlabel>
before , <h:message>
after makes refactoring more reasonable.
Comments
Post a Comment