Apache Tapestry - wbudowane komponenty

Ten rozdział wyjaśnia wbudowane komponenty, które ma Tapestry, wraz z odpowiednimi przykładami. Tapestry obsługuje ponad 65 wbudowanych komponentów. Możesz także tworzyć komponenty niestandardowe. Omówmy szczegółowo niektóre z ważnych elementów.

Jeśli Component

Komponent if jest używany do warunkowego renderowania bloku. Stan jest sprawdzany za pomocą parametru testowego.

Utwórz stronę IfSample.java jak pokazano poniżej -

package com.example.MyFirstApplication.pages;  

public class Ifsample {
   public String getUser() { 
      return "user1"; 
   } 
}

Teraz utwórz odpowiedni plik szablonu w następujący sposób -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
     
   <h3>If-else component example </h3> 
   <t:if test = "user"> 
      Hello ${user} 
      <p:else>
         <h4> You are not a Tapestry user </h4> 
      </p:else> 
   </t:if> 
</html>

Żądanie strony spowoduje wyrenderowanie wyniku, jak pokazano poniżej.

Result - http: // localhost: 8080 / MyFirstApplication / ifsample

Chyba że i deleguj składnik

Plik unless componentjest przeciwieństwem komponentu if, który został omówiony powyżej. Podczas, gdydelegate componentnie wykonuje żadnego renderowania samodzielnie. Zamiast tego zwykle deleguje znaczniki do elementu blokowego. Chyba że i jeśli składniki mogą używać delegata i bloku do warunkowej zamiany zawartości dynamicznej.

Utwórz stronę Unless.java następująco.

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.Block; 
import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.ioc.annotations.Inject; 
import org.apache.tapestry5.PersistenceConstants; 
import org.apache.tapestry5.annotations.Persist;  

public class Unless { 
   @Property 
   @Persist(PersistenceConstants.FLASH) 
   private String value;  
   @Property 
   private Boolean bool; 
   @Inject 
   Block t, f, n;  
   
   public Block getCase() { 
      if (bool == Boolean.TRUE ) { 
         return t; 
      } else { 
         return f; 
      } 
   }   
}

Teraz utwórz odpowiedni plik szablonu w następujący sposób -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
  
   <h4> Delegate component </h4> 
   <div class = "div1"> 
      <t:delegate to = "case"/> 
   </div> 
   <h4> If-Unless component </h4>  
   
   <div class = "div1"> 
      <t:if test = "bool"> 
         <t:delegate to = "block:t"/> 
      </t:if> 
      <t:unless test = "bool"> 
         <t:delegate to = "block:notT"/> 
      </t:unless> 
   </div>  
   
   <t:block id = "t"> 
      bool == Boolean.TRUE. 
   </t:block> 
   
   <t:block id = "notT"> 
      bool = Boolean.FALSE. 
   </t:block> 
   
   <t:block id = "f"> 
      bool == Boolean.FALSE. 
   </t:block> 
</html>

Żądanie strony spowoduje wyrenderowanie wyniku, jak pokazano poniżej.

Result - http: // localhost: 8080 / MyFirstApplication / chyba

Komponent pętli

Składnik pętli jest podstawowym składnikiem do zapętlania elementów kolekcji i renderowania treści dla każdej wartości / iteracji.

Utwórz stronę pętli, jak pokazano poniżej -

Loop.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class Loop { 
   @Property 
   private int i; 
}

Następnie utwórz odpowiedni szablon Loop.tml

Loop.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <p>This is sample parameter rendering example...</p> 
   <ol>
      <li t:type = "loop" source = "1..5" value = "var:i">${var:i}</li> 
   </ol> 
</html>

Składnik pętli ma następujące dwa parametry -

  • source- Źródło kolekcji. 1… 5 to rozwinięcie właściwości używane do tworzenia tablicy z określonym zakresem.

  • var- Zmienna renderowania. Służy do renderowania bieżącej wartości w treści szablonu.

Żądanie strony spowoduje wyrenderowanie wyniku, jak pokazano poniżej -

Składnik PageLink

Komponent PageLink służy do łączenia strony z jednej strony na inną. Utwórz stronę testową PageLink, jak poniżej -PageLink.java.

package com.example.MyFirstApplication.pages;  
   public class PageLink { 
}

Następnie utwórz odpowiedni plik szablonu, jak pokazano poniżej -

PageLink.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <body> 
      <h3><u>Page Link</u> </h3> 
      <div class = "page"> 
         <t:pagelink page = "Index">Click here to navigate Index page</t:pagelink>
         <br/> 
      </div> 
   </body> 
   
</html>

Komponent PageLink zawiera parametr strony, który powinien odnosić się do docelowej strony tapestry.

Result - http: // localhost: 8080 / myFirstApplication / pagelink

Składnik EventLink

Składnik EventLink wysyła nazwę zdarzenia i odpowiadający mu parametr za pośrednictwem adresu URL. Utwórz klasę strony EventsLink, jak pokazano poniżej.

EventsLink.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class EventsLink { 
   @Property 
   private int x; 
   void onActivate(int count) { 
      this.x = x; 
   } 
   int onPassivate() { 
      return x; 
   } 
   void onAdd(int value) { 
      x += value; 
   }   
}

Następnie utwórz odpowiedni plik szablonu „EventsLink” w następujący sposób -

EventsLink.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <h3> Event link example </h3> 
   AddedCount = ${x}. <br/> 
   <t:eventlink t:event = "add" t:context = "literal:1">
      Click here to add count
   </t:eventlink><br/>  
</html>

EventLink ma następujące dwa parametry -

  • Event- nazwa zdarzenia, które ma zostać wyzwolone w składniku EventLink. Domyślnie wskazuje na identyfikator komponentu.

  • Context- Jest to parametr opcjonalny. Określa kontekst odsyłacza.

Result - http: // localhost: 8080 / myFirstApplication / EventsLink

Po kliknięciu wartości licznika strona wyświetli nazwę zdarzenia w adresie URL, jak pokazano na poniższym zrzucie ekranu wyjściowego.

Składnik ActionLink

Składnik ActionLink jest podobny do składnika EventLink, ale wysyła tylko identyfikator składnika docelowego. Domyślna nazwa zdarzenia to akcja.

Utwórz stronę „ActivationLinks.java”, jak pokazano poniżej,

ActivationLinks.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class ActivationLinks {  
   @Property 
   private int x;  
   void onActivate(int count) { 
      this.x = x; 
   }  
   int onPassivate() { 
      return x; 
   } 
   void onActionFromsub(int value) { 
      x -= value; 
   } 
}

Teraz utwórz odpowiedni plik szablonu, jak pokazano poniżej -

ActivationLinks.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <div class = "div1"> 
      Count = ${count}. <br/> 
      <t:actionlink t:id = "sub" t:context = "literal:1">
         Decrement
      </t:actionlink><br/> 
   </div> 
   
</html>

Tutaj OnActionFromSub zostanie wywołana po kliknięciu składnika ActionLink.

Result - http: // localhost: 8080 / myFirstApplication / ActivationsLink

Alert Component

Okno dialogowe ostrzeżenia jest najczęściej używane do wysyłania ostrzeżeń do użytkowników. Na przykład, jeśli pole wejściowe wymaga jakiegoś obowiązkowego tekstu, ale użytkownik nie wprowadza żadnych danych wejściowych, wówczas w ramach walidacji można użyć pola ostrzegawczego, aby wysłać komunikat ostrzegawczy.

Utwórz stronę „Alerty”, jak pokazano w następującym programie.

Alerts.java

package com.example.MyFirstApplication.pages;  

public class Alerts { 
   public String getUser() { 
      return "user1"; 
   } 
}

Następnie utwórz odpowiedni plik szablonu w następujący sposób -

Alerts.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"  
   xmlns:p = "tapestry:parameter">  
   
   <h3>Alerts</h3> 
   <div class = "alert alert-info"> 
      <h5> Welcome ${user} </h5> 
   </div>
   
</html>

Alert ma trzy poziomy ważności, które są:

  • Info
  • Warn
  • Error

Powyższy szablon jest tworzony za pomocą alertu informacyjnego. Jest zdefiniowany jakoalert-info. W zależności od potrzeb możesz utworzyć inne poziomy ważności.

Żądanie strony spowoduje następujący wynik -

http://localhost:8080/myFirstApplication/Alerts