我正在使用 PrimeFaces 6.1 版。我需要以图表格式显示我的数据。为此,我将 GChart 组件实现为链接https://www.primefaces.org/showcase-ext/sections/gchart/basic.jsf。我在我的表单中添加了链接,点击该链接,我已经渲染了图表。我需要以这种形式显示不同的图表。所以我有不同的面板来显示不同的图表点击不同的按钮。当页面加载并第一次单击链接时,图表会正确呈现。下次当我单击相同的链接时,整个页面变为空白。我在控制台中搜索错误,出现如下错误:
我需要刷新页面才能使我的页面处于工作状态。我尝试通过为 pe:gChart 标记提供 id,当我单击链接图表时出现,并且在下一次单击页面上变为空白,并且由于未定义具有新给定 id 的容器而出现错误。我的视图代码是这样的:
<script src="https://www.gstatic.com/charts/loader.js"></script>
<h:form id="dash">
<p:commandLink id="savButton" class="small-box-footer" action="#{dashboardMB.createPieModel1}" update="@form">
<h:outputLabel styleClass="np" value="#{text.Detail}"/>
<i class="fa fa-arrow-circle-right"></i>
</p:commandLink>
<p:panel header="#{text.Saving}" rendered="#{dashboardMB.savVisible}" id="panelSav" closable="false" toggleable="true" >
<p:outputPanel id="container1" layout="block">
<div id="savChart">
<pe:gChart value="#{dashboardMB.savingChartModel}" width="400" height="400"
title="Saving Wise">
</pe:gChart>
</div>
</p:outputPanel>
</p:panel>
我的托管 bean 代码是这样的:
public void createPieModel1() {
isSavVisible=true;
DashboardModel dashObj=new DashboardModel();
dashObj=dashBoardEJB.getvalues();
chartSavingModel = new GChartModelBuilder()
.setChartType(GChartType.COLUMN)
.addColumns("Topping", "Slices")
.addRow("A", dashObj.getCount1())
.addRow("V", dashObj.getCount2())
.addRow("Z", dashObj.getCount3())
.addRow("W", dashObj.getCount4())
.build();
}