Wicket:如何在不丢失现有输入的情况下重新呈现当前表单?

时间:2010-12-16 10:11:21

标签: ajax forms internationalization wicket preserve

我有一个带有组合框/下拉列表的表单来选择用户语言。如果用户更改了语言,我想更新所有标签,但保留输入元素。

在jQuery中,我通过JSON请求标签ID列表和新文本,然后使用这样的循环:

var texts = {[ {id:'nameLabel', text:'First Name'}, {id:'familyLabel', text:'Family Name'} ]};
for( var i=0; i<texts.length; i++) {
    var item = texts[i];
    $('#'+item.id).text(item.text);
}

这将更新所有标签而不修改任何其他标签。我如何在Wicket中做到这一点?

[编辑]我尝试了什么:

        DropDownChoice<Locale> ddc = new DropDownChoice<Locale>(...);
        ddc.add( new AjaxFormComponentUpdatingBehavior("onchange") {
            private static final long serialVersionUID = 1L;

            @Override
            protected void onUpdate( AjaxRequestTarget target ) {
                getSession().setLocale( language );
                for( MarkupContainer label : labels ) {
                    target.addComponent( label );
                }
            }
        });

这确实会更改标签,但它也会再次呈现所有输入字段。我发现无法访问输入字段的当前值。

[EDIT2]标签列表的创建方式如下:

        StringResourceModel usernameLabel = new StringResourceModel("usernameLabel", this, new Model<ValueMap>(map));
        labels.add(add(new Label("usernameLabel", usernameLabel)));

1 个答案:

答案 0 :(得分:1)

这是错误的:

labels.add(add(new Label("usernameLabel", usernameLabel)));

您没有将Label实例添加到'标签',它会反复添加您要添加​​的容器(可能是Page实例)。方法'add()'不返回正在添加的组件,它返回要添加组件的容器。

尝试将其更改为:

Label label = new Label("usernameLabel", usernameLabel);
add(label);
labels.add(label);