生活随笔
收集整理的這篇文章主要介紹了
JSF pickList
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
<h:form>
<p:growl id=“msg” showDetail=“true” escape=“false” />
<h3 style="margin-top: 0">Basic PickList</h3>
<p:pickList id="pickList" value="#{pickListView.cities}" var="cities" itemLabel="#{cities}" itemValue="#{cities}" /><p:commandButton id="citySubmit" value="Submit" update="displayCities" oncomplete="PF('cityDialog').show()" style="margin-top:5px" /><h3>PickList on Steroids: Pojo Support with Effect, Captions, Custom Content, Reordering, Filtering, Checkboxes, <br />Ajax Events and Responsive</h3>
<p:pickList id="PojoPickList" value="#{pickListView.themes}" var="theme" effect="bounce"itemValue="#{theme}" itemLabel="#{theme.displayName}" showSourceControls="true" showTargetControls="true" showCheckbox="true"showSourceFilter="true" showTargetFilter="true" filterMatchMode="contains" converter="theme" responsive="true"><f:facet name="sourceCaption">Available</f:facet><f:facet name="targetCaption">Starting</f:facet><p:ajax event="transfer" listener="#{pickListView.onTransfer}" update="msg" /><p:ajax event="select" listener="#{pickListView.onSelect}" update="msg"/><p:ajax event="unselect" listener="#{pickListView.onUnselect}" update="msg"/><p:ajax event="reorder" listener="#{pickListView.onReorder}" update="msg"/><p:column style="width:15%"><h:graphicImage name="showcase/images/themeswitcher/themeswitcher-#{theme.name}.png" alt="#{theme.name}" styleClass="ui-theme"/></p:column><p:column style="width:85%;"><h:outputText value="#{theme.displayName}" /></p:column>
</p:pickList><p:commandButton id="pojoSubmit" value="Submit" update="displayThemes" oncomplete="PF('themesDialog').show()" style="margin-top:5px" /><p:dialog modal="true" showEffect="fade" hideEffect="fade" widgetVar="cityDialog"><h:panelGrid id="displayCities" columns="2"><h:outputText value="Source: " style="font-weight:bold" /><ui:repeat value="#{pickListView.cities.source}" var="item"><h:outputText value="#{item}" style="margin-right:5px" /></ui:repeat><h:outputText value="Target: " style="font-weight:bold" /><ui:repeat value="#{pickListView.cities.target}" var="item"><h:outputText value="#{item}" style="margin-right:5px" /></ui:repeat></h:panelGrid>
</p:dialog><p:dialog modal="true" showEffect="fade" hideEffect="fade" widgetVar="themesDialog"><h:panelGrid id="displayThemes" columns="2"><h:outputText value="Source: " style="font-weight:bold" /><ui:repeat value="#{pickListView.themes.source}" var="theme"><h:outputText value="#{theme.name}" style="margin-right:5px" /></ui:repeat><h:outputText value="Target: " style="font-weight:bold" /><ui:repeat value="#{pickListView.themes.target}" var="theme"><h:outputText value="#{theme.name}" style="margin-right:5px" /></ui:repeat></h:panelGrid>
</p:dialog>
</h:form>
@ManagedBean
public class PickListView {
@ManagedProperty("#{themeService}")
private ThemeService service;private DualListModel<String> cities;
private DualListModel<Theme> themes;@PostConstruct
public void init() {//CitiesList<String> citiesSource = new ArrayList<String>();List<String> citiesTarget = new ArrayList<String>();citiesSource.add("San Francisco");citiesSource.add("London");citiesSource.add("Paris");citiesSource.add("Istanbul");citiesSource.add("Berlin");citiesSource.add("Barcelona");citiesSource.add("Rome");cities = new DualListModel<String>(citiesSource, citiesTarget);//ThemesList<Theme> themesSource = service.getThemes().subList(0, 5);List<Theme> themesTarget = new ArrayList<Theme>();themes = new DualListModel<Theme>(themesSource, themesTarget);}public DualListModel<String> getCities() {return cities;
}public void setCities(DualListModel<String> cities) {this.cities = cities;
}public ThemeService getService() {return service;
}public void setService(ThemeService service) {this.service = service;
}public DualListModel<Theme> getThemes() {return themes;
}public void setThemes(DualListModel<Theme> themes) {this.themes = themes;
}public void onTransfer(TransferEvent event) {StringBuilder builder = new StringBuilder();for(Object item : event.getItems()) {builder.append(((Theme) item).getName()).append("<br />");}FacesMessage msg = new FacesMessage();msg.setSeverity(FacesMessage.SEVERITY_INFO);msg.setSummary("Items Transferred");msg.setDetail(builder.toString());FacesContext.getCurrentInstance().addMessage(null, msg);
} public void onSelect(SelectEvent event) {FacesContext context = FacesContext.getCurrentInstance();context.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, "Item Selected", event.getObject().toString()));
}public void onUnselect(UnselectEvent event) {FacesContext context = FacesContext.getCurrentInstance();context.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, "Item Unselected", event.getObject().toString()));
}public void onReorder() {FacesContext context = FacesContext.getCurrentInstance();context.addMessage(null, new FacesMessage(FacesMessage.SEVERITY_INFO, "List Reordered", null));
}
}
總結(jié)
以上是生活随笔為你收集整理的JSF pickList的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。