我有一个要修改字体大小的 DataTable。用户可以使用 selectOneMenue 组件设置字体大小。
现在,如果我用 jQuery 更新它,这只发生在第一次。如果我想通过 selectOneMenue 更改字体大小,则字体大小设置为默认值,如果我进行刷新 (F5),则字体大小将成功更改。但我不想要这种行为。
所以我在脚本部分添加了 reload() 函数。如果我这样做,如果我想重新加载,我总是会收到这条 Firefox 消息.....然后它会以默认大小呈现表格,并在呈现正确的字体大小后不久。所以最终产品没问题,但我不希望出现这个必须提交的 firefox 消息,我还想关闭使用默认字体大小的表格的预渲染。
现在我有这个代码
<script>
jQuery(document)
.ready(
function() {
jQuery('#dtSummary')
.css('cssText',
'font-size:#{summaryBean.selectedFont}px !important');
});
function changeFont() {
document.getElementById("dtSummary").style.fontSize = "#{summaryBean.selectedFont}px !important;}";
window.location.reload(true);
}
</script>
<h:form id="form" prependId="false">
<h:panelGroup>
<h:panelGrid columns="3" styleClass="rainstar-form-inline"
columnClasses="rainstar-form-column-left rainstar-form-column-right">
<p:selectOneMenu id="targ" effect="fade"
styleClass="rainstar-input-small2"
value="#{summaryBean.selectedFont}"
valueChangeListener="#{summaryBean.selectionFont_change}"
onchange="changeFont()">
<f:selectItems value="#{summaryBean.fontCollection}" />
<p:ajax update="dtSummary" />
</p:selectOneMenu>
</h:panelGrid>
<p:commandButton value="#{msg.button_print}" icon="ui-icon-print"
styleClass="rainstar-button-right"
action="#{summaryBean.generatePdf()}" ajax="false" />
<p:dataTable id="dtSummary" styleClass="rainstar-form-margin-top"
value="#{summaryBean.eintragList}"
selection="#{summaryBean.selectedEintrag}" selectionMode="multiple"
var="eintrag" rowKey="#{eintrag.it1}">
<p:column id="header" styleClass="ui-state-default">
<div class="ui-dt-c">#{eintrag.it1}</div>
</p:column>
<p:column styleClass="rainstar-table-item"
headerText="#{tableBundleBean.summary_table_nozzles} [mm]">
<h:outputText value="#{eintrag.it2}" />
</p:column>
</p:dataTable>
</h:panelGroup>
</h:form>