2011-10-26 65 views
2

我在<a/>标记中有一个组件,它在点击时打开一个弹出窗口。这是一个适用于KML文件的“添加到最爱”链接。我的KML文件有一个名为“favorite [boolean]”的字段。现在我想隐藏或显示我的“添加到最爱”链接。在Wicket中隐藏组件

public class CustomTracksAjaxDataTable<T> extends CustomAjaxDataTable<T> { 
    public CustomTracksAjaxDataTable(String id, List<IColumn<T>> iColumns, 
     ISortableDataProvider<T> tiSortableDataProvider, int rowsPerPage) { 
     super(id, iColumns, tiSortableDataProvider, rowsPerPage); 
    } 

    protected void onEventHandler(AjaxRequestTarget ajaxRequestTarget, 
     KMLFile file) { 
     setKMLData(file); // it just update map, dont care about it 
     add(new FavouriteStarIconState(file.isSaved())); 
    } 
} 

我尝试添加因而行为:

<div id="map_container"> 
    <a wicket:id="favourite_star" class="map_container_star"></a> 
</div> 

这ISN”:

public class FavouriteStarIconState extends AbstractDefaultAjaxBehavior { 
    private boolean isFavourite; 

    public FavouriteStarIconState(boolean isFavourite) { 
     super(); 
     this.isFavourite = isFavourite; 
    } 

    @Override 
    protected void respond(AjaxRequestTarget target) { 
     if (isFavourite) { 
      target.appendJavascript("jQuery('.map_container_star').css(
       {'display' : 'none' });"); 
     } else { 
      target.appendJavascript("jQuery('.map_container_star').css(
       {'display' : 'block' });"); 
     } 
    } 

    @Override 
    public void renderHead(IHeaderResponse response) { 
     response.renderOnLoadJavascript(getCallbackScript().toString()); 
    } 
} 

包含该组件的HTML的一部分与一个表生成的KML列表不工作。我得到了与component.setVisible(false)相同的结果。我怎样才能隐藏起来工作?

+1

你是否看了'ISVISIBLE()''Component'的方法是什么?你可以覆盖它,Wicket会处理剩下的事情,你只需要将组件添加到'AjaxRequestTarget'。这个解决方案有一些限制,但通常是有效的。 – biziclop

回答

1

那么它发现我犯了一个可怕的错误,并把JavaScript附加到错误的地方。 AJAX请求未呈现。正确的类是由我的类CustomTracksAjaxDataTable扩展的CustomAjaxDataTable。我只是添加

new AjaxEventBehavior("onclick") 

,并覆盖

protected void onEvent(AjaxRequestTarget ajaxRequestTarget) 

,它的伟大工程,现在

0

你可以使用一个CSS类这样

.hiddenClass 
{ 
    visibility:hidden; 
} 

然后用AttributeModifier你的类添加到元素

component.add(new AttributeModifier("class", "hiddenClass")); 

或直接添加样式到风格属性

component.add(new AttributeModifier("style", "visibility:hidden;")); 
+0

我得到'构造函数AttributeModifier(String,String)未定义'。也许我正在使用不同版本的Wicket。 –

+0

可能,答案是4岁 – osdamv