В настоящее время у меня есть две командные кнопки и один список. На основе выбора списка, сгенерированный результат может отображаться в файле, который можно загрузить, или отображается как таблица HTML. Код getFile()
основан на Учебном пособии по обработке BalusC PDF, а getTable()
устанавливает resultTable
.
<h:form>
<fieldset>
<h:selectManyListbox id="listbox" value="#{form.items}">
<f:selectItems value="#{form.allItems}">
</h:selectManyListbox>
</fieldset>
<h:commandButton value="Get File" action="#{form.getFile}">
<h:commandButton value="Get Table" action="#{form.getTable}">
<f:ajax render="result_table" execute="listbox" />
</h:commandButton>
<h:panelGrid id="result_table">
<table>
<thead></thead>
<tbody>
<ui:repeat var="table" value="#{form.resultTable}">
</ui:repeat>
</tbody>
</table>
</h:panelGrid>
Обе кнопки работают до сих пор. Однако я хочу объединить оба действия в одну кнопку. Когда я тестирую это с помощью кнопки, которая запускает оба действия, ничего не происходит (нет сохранения файла в виде диалога или таблицы). Это потому, что одно действие является ajax или потому что другое действие завершается с помощью facesContext.responseComplete();
?
<h:commandButton value="Get Both" action="#{form.getBoth}">
<f:ajax render="result_table" execute="listbox" />
</h:commandButton>
getBoth() {
getTable();
getFile();
}
Кроме того, я хотел бы установить флажок, если он установлен, сохранить, как открывается диалоговое окно, и отображается таблица. Если он не установлен, отображается только таблица.