子组件未通过 onConfigure 更新下拉选择
Subcomponent not updating on dropdown selection via onConfigure
我有一个下拉菜单,根据选择更新页面上的一些免责声明文本。下拉菜单和免责声明各有其自己的面板(自己的标记和组件)。我想让它在第一次加载页面时不显示免责声明。任何时候从下拉列表中进行选择时,都会显示免责声明。
DropDownPanel.java
private boolean firstTimeLoaded = true;
...
disclaimerPanel = new DisclaimerPanel( "disclaimer", contactModel, firstTimeLoaded );
disclaimerPanel.setOutputMarkupId( true );
disclaimerPanel.setOutputMarkupPlaceholderTag( true );
...
dropDownChoice.getInternalComponent().add( new AjaxFormComponentUpdatingBehavior( "onchange" )
{
@Override
protected void onUpdate( AjaxRequestTarget ajaxRequestTarget )
{
// METHOD 1
disclaimerPanel = new Disclaimer( "disclaimer", contactModel, !firstTimeLoaded );
disclaimerPanel.setOutputMarkupPlaceholderTag( true );
disclaimerPanel.setOutputMarkupId( true );
// METHOD 2
// remove code from METHOD 1 as onConfigure should set visibility of DisclaimerPanel using addComponent
ajaxRequestTarget.addComponent( disclaimerPanel );
ajaxRequestTarget.addChildren( disclaimerPanel, Component.class );
}
DisclaimerPanel.java
private boolean firstTimeLoaded;
public DisclaimerPanel( String id, IModel<Contact> contactModel, boolean firstTimeLoaded )
{
...
this.firstTimeLoaded = firstTimeLoaded;
}
@Override
protected void onConfigure()
{
setVisible( !firstTimeLoaded );
}
我已经尝试了两种方法,但都不起作用(方法 1、方法 2)。从断点开始,onConfigure
第一次运行并正确隐藏了免责声明。当我做出选择时;然而, DisclaimerPanel
with firstTimeLoaded
as false
but onConfigure
的构造函数没有被执行。我错过了什么?
提前致谢!
无需在 onUpdate() 中创建 DisclaimerPanel 的新实例。您只需要切换其 firstTimeLoaded
值,然后将 disclaimerPanel
添加到 AjaxRequestTarget。您可以将 firstTimeLoaded
的 setter 添加到 DisclaimerPanel,或使用 IModel<Boolean>
而不是普通的 boolean
作为构造函数参数。
在您创建新实例的代码中,您需要将旧实例替换为:replace(disclaimerPanel)
。这是必需的,因为在 Wicket 中,页面就像一个树数据结构——页面是根,它可能有分支——它的第一级组件,它们可能有自己的分支——它们的子组件,等等。所以在这里你创建 DisclaimerPanel 的新实例,但不将其添加到任何父组件。您需要使用 parent.replace(disclaimerPanel)
,然后将 disclaimerPanel
添加到 AjaxRequestTarget,以便 Wicket 在 Ajax 响应中呈现其 HTML。
我有一个下拉菜单,根据选择更新页面上的一些免责声明文本。下拉菜单和免责声明各有其自己的面板(自己的标记和组件)。我想让它在第一次加载页面时不显示免责声明。任何时候从下拉列表中进行选择时,都会显示免责声明。
DropDownPanel.java
private boolean firstTimeLoaded = true;
...
disclaimerPanel = new DisclaimerPanel( "disclaimer", contactModel, firstTimeLoaded );
disclaimerPanel.setOutputMarkupId( true );
disclaimerPanel.setOutputMarkupPlaceholderTag( true );
...
dropDownChoice.getInternalComponent().add( new AjaxFormComponentUpdatingBehavior( "onchange" )
{
@Override
protected void onUpdate( AjaxRequestTarget ajaxRequestTarget )
{
// METHOD 1
disclaimerPanel = new Disclaimer( "disclaimer", contactModel, !firstTimeLoaded );
disclaimerPanel.setOutputMarkupPlaceholderTag( true );
disclaimerPanel.setOutputMarkupId( true );
// METHOD 2
// remove code from METHOD 1 as onConfigure should set visibility of DisclaimerPanel using addComponent
ajaxRequestTarget.addComponent( disclaimerPanel );
ajaxRequestTarget.addChildren( disclaimerPanel, Component.class );
}
DisclaimerPanel.java
private boolean firstTimeLoaded;
public DisclaimerPanel( String id, IModel<Contact> contactModel, boolean firstTimeLoaded )
{
...
this.firstTimeLoaded = firstTimeLoaded;
}
@Override
protected void onConfigure()
{
setVisible( !firstTimeLoaded );
}
我已经尝试了两种方法,但都不起作用(方法 1、方法 2)。从断点开始,onConfigure
第一次运行并正确隐藏了免责声明。当我做出选择时;然而, DisclaimerPanel
with firstTimeLoaded
as false
but onConfigure
的构造函数没有被执行。我错过了什么?
提前致谢!
无需在 onUpdate() 中创建 DisclaimerPanel 的新实例。您只需要切换其 firstTimeLoaded
值,然后将 disclaimerPanel
添加到 AjaxRequestTarget。您可以将 firstTimeLoaded
的 setter 添加到 DisclaimerPanel,或使用 IModel<Boolean>
而不是普通的 boolean
作为构造函数参数。
在您创建新实例的代码中,您需要将旧实例替换为:replace(disclaimerPanel)
。这是必需的,因为在 Wicket 中,页面就像一个树数据结构——页面是根,它可能有分支——它的第一级组件,它们可能有自己的分支——它们的子组件,等等。所以在这里你创建 DisclaimerPanel 的新实例,但不将其添加到任何父组件。您需要使用 parent.replace(disclaimerPanel)
,然后将 disclaimerPanel
添加到 AjaxRequestTarget,以便 Wicket 在 Ajax 响应中呈现其 HTML。