2012-08-02 11 views
5

w moim bieżącym projekcie napotkałem problem z dostosowaniem IndicacyAjaxLink w furtce, czy istnieje jakieś rozwiązanie, aby zmienić standardowy obraz gif na mój własny? Na przykład mamy następujące listeneerDostosowywanie wskaźnika AjaxLink w furtce

add(new IndicatingAjaxLink("closeReceivedBillspanel") { 
      public void onClick(AjaxRequestTarget art) { 
        // some timeconsuming calculations 
      } 
    }); 

jako użytkownik kliknie ten link, pojawi się gif z załadunku i chcę zmienić to gif, czy istnieje jakieś rozwiązanie tego problemu?

Odpowiedz

13

Wyraź swoją stronę implementuje interfejs IAjaxIndicatorAware

public class BasePage extends WebPage implements IAjaxIndicatorAware { 

public BasePage(final PageParameters parameters) { 
    // Home link 
    AjaxLink<Page> homeLink = new AjaxLink<Page>("homeLink") { 
     private static final long serialVersionUID = 1L; 

     @Override 
     public void onClick(AjaxRequestTarget target) { 
     setResponsePage(HomePage.class); 
     } 
    }; 
    add(homeLink); 
    } 

    @Override 
    public String getAjaxIndicatorMarkupId() { 
    return "indicator"; 
    } 

W ten sposób można ustawić w html, każdy obraz, który chcesz wyświetlić, gdy ładowanie pojawia się zmiana wizerunku w „img” tag

<div id="indicator" style="display: none;"> 
<div class="indicator-content"> 
    Please wait... <wicket:link><img src="images/loading.gif" width="16" height="16" alt="loading" /></wicket:link> 
</div> 
</div> 
2

Tworzenie yoru właścicielem zwyczaj klasa jak (skopiować co jest w środku IndicatingAjaxLink i aktualizacja)

public class MyIndicatingAjaxLink<T> extends AjaxLink<T> implements IAjaxIndicatorAware { 
     private final MyAjaxIndicatorAppender indicatorAppender = new MyAjaxIndicatorAppender();  
    . 
    //rest of the code is same as IndicatingAjaxLink class 
    . 
    } 

Również trzeba niestandardowego AjaxIndicatorAppender w swojej customIndicatingAjaxLink i trzeba zastąpić poniżej metody indicatorAppender powrotu ścieżkę swojego zwyczaju obraz

protected CharSequence getIndicatorUrl()