Olá pessoal,
Estou aqui para escrever mais um post que acho que vai ser bastante útil, pois quando eu precisei, achei tudo muito costurado, uma parte em um post, outra parte em outro post e assim por diante. Quero lembrar que vou fazer aqui componentes criados através do bean, por código e chamado na tag binding dos componentes do JSF e usarei o primefaces, mas podem usar da mesma forma para componentes do próprio jsf que funciona da mesma forma.
Qual será a ideia?
A ideia é criar um painel com um número a escolha de outputLabel e inputText.
Então que variáveis precisamos?
Precisaremos das variáveis abaixo:
FacesContext context;
ELContext elContext;
private InputText in;
private OutputLabel opl;
private PanelGrid panel;
Precisaremos pegar o contexto e também os OutputLabel e InputText, sem esquecer do PanelGrid.
Os pacotes que estão os componentes são:
import org.primefaces.component.inputtext.InputText;
import org.primefaces.component.outputlabel.OutputLabel;
import org.primefaces.component.panelgrid.PanelGrid;
Pronto, com isso temos os componentes no bean, agora precisamos saber se realmente vai funcionar a criação, por isso no construtor do bean declaramos:
panel = new PanelGrid(); (1) panel.setId("pnlDinamico"); (2) panel.setColumns(2); (3)
Acima inciamos criando o Painel (1), setamos o id dele (2), neste caso é único, pois é um painel apenas e declaramos o número de coluna que se fosse na view seria desta maneira:
<p:panelgrid columns="2" id="pnlDinamico"></p:panelgrid>
Para ver se realmente funcionou devemos colocar o seguinte código:
<p:panelGrid binding="#{bean.panel}">
<f:facet name="header">
Panel Dinamico
</f:facet>
</p:panelGrid>
Pronto com esse código vcoê vai visualizar um panelgrid sem nenhum dado somente com o nome Panel Dinâmico.
No próximo post a gente continua. Até lá!
Link para parte 2
Nenhum comentário:
Postar um comentário