Wicket - 从另一个面板设置模型

问题描述 投票:1回答:1

我对Wicket很新。我在按钮单击时从主面板(ChartPanel)向子面板(MainPanel)添加模型。

MainPanel.java

单击按钮,我在更改模型后重新添加chartPanel。以下是我在MainPanel的buttonClick中使用的代码。这里的onRenderAnnotations事件是在UI中的某些点击中生成的。

 @OnEvent
public void onRenderAnnotations(RenderAnnotationsEvent aEvent)
{
    LOG.trace("clicked on the annotation");

    renderChart( aEvent.getRequestHandler());
}

private void renderChart(IPartialPageRequestHandler aRequestHandler)
{
    MultiValuedMap<String, Double> recommenderScoreMap = getLatestScores(aRequestHandler);
    Map<String,String> curveData = new HashMap<String,String>();
    LearningCurve learningCurve = new LearningCurve();

    for (String recommenderName : recommenderScoreMap.keySet()) {
        String data = recommenderScoreMap.get(recommenderName).stream().map(Object::toString)
                .collect(Collectors.joining(", "));

        curveData.put(recommenderName,data);

        learningCurve.setCurveData(curveData);

        learningCurve.setMaximumPointsToPlot(MAX_POINTS_TO_PLOT);
    }
    chartPanel.setDefaultModel(Model.of(learningCurve));

    // to avoid the error, A partial update of the page is being rendered
    try {
        aRequestHandler.add(chartPanel);
    }
    catch (IllegalStateException e) {
        LOG.warn("Not updating the chart. " + e.toString());
        setResponsePage(getPage());
    }
}

ChartPanel.java

在chartPanel之后,我想使用更新的模型在chartpanel中添加组件。最好的方法是什么?

我想在ChartPanel类中做类似的事情:

@Override
protected void onRender()
{
    super.onModelChanged();

    LearningCurve newLearningCurve = getModel().getObject();

    requestTarget = ???

    String js = createJavascript(newLearningCurve);
    requestTarget.prependJavascript(js);
}

我的问题是,在上面的代码中如何获取请求目标,因为它不是ajax请求,我也不会在参数中得到它。我应该使用其他功能,我也得到一个requestTarget。但我希望每次从任何地方更新ChartPanel模型时都会调用它。

请原谅我的无知。我已经尝试了几天,但我仍然卡住了。我试图解释它,但如果缺少任何信息,请评论,我会立即添加。

谢谢。

java wicket wicket-6 wicket-1.5
1个回答
2
投票

你应该改写renderHead()

@Override
public void renderHead(IHeaderResponse response)
{
    super.renderHead(response);

    response.render(OnLoadHeaderItem.forScript(
            createJavascript(newLearningCurve)));
}

这样,无论是由于AjaxRequest还是仅在重新呈现页面时添加,您的图表都将正确显示。

© www.soinside.com 2019 - 2024. All rights reserved.