JSP - Özel Etiketler

Bu bölümde, JSP'deki Özel Etiketleri tartışacağız. Özel etiket, kullanıcı tanımlı bir JSP dil öğesidir. Özel bir etiket içeren bir JSP sayfası bir sunucu uygulamasına çevrildiğinde, etiket, etiket işleyici olarak adlandırılan bir nesne üzerindeki işlemlere dönüştürülür. Web kapsayıcısı daha sonra JSP sayfasının sunucu uygulaması yürütüldüğünde bu işlemleri başlatır.

JSP etiket uzantıları, bir JavaSunucusu Sayfasına doğrudan ekleyebileceğiniz yeni etiketler oluşturmanıza olanak sağlar. JSP 2.0 spesifikasyonu, bu özel etiketleri yazmak için Basit Etiket İşleyicileri tanıttı.

Özel bir etiket yazmak için, basitçe SimpleTagSupport sınıf ve geçersiz kılma doTag() etiket için içerik oluşturmak üzere kodunuzu yerleştirebileceğiniz yöntem.

"Merhaba" Etiketi Oluşturun

<Ex: Hello> adlı özel bir etiket tanımlamak istediğinizi ve bunu aşağıdaki şekilde gövde olmadan kullanmak istediğinizi düşünün -

<ex:Hello />

Özel bir JSP etiketi oluşturmak için, önce bir etiket işleyici görevi gören bir Java sınıfı oluşturmanız gerekir. Şimdi oluşturalımHelloTag aşağıdaki gibi sınıf -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   public void doTag() throws JspException, IOException {
      JspWriter out = getJspContext().getOut();
      out.println("Hello Custom Tag!");
   }
}

Yukarıdaki kod, basit bir kodlamaya sahiptir. doTag() yöntemi, geçerli JspContext nesnesini kullanarak getJspContext() yöntem ve onu göndermek için kullanır "Hello Custom Tag!" akıntıya JspWriter nesne

Yukarıdaki sınıfı derleyelim ve CLASSPATH ortam değişkeninde bulunan bir dizine kopyalayalım. Son olarak, aşağıdaki etiket kitaplığı dosyasını oluşturun:<Tomcat-Installation-Directory>webapps\ROOT\WEB-INF\custom.tld.

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>empty</body-content>
   </tag>
</taglib>

Şimdi yukarıda tanımlanan özel etiketi kullanalım Hello JSP programımızda aşağıdaki gibi -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello/>
   </body>
</html>

Yukarıdaki JSP'yi arayın ve bu aşağıdaki sonucu vermelidir -

Hello Custom Tag!

Etiket Gövdesine Erişim

Standart etiketlerde gördüğünüz gibi etiketin gövdesine bir mesaj ekleyebilirsiniz. Adlı özel bir etiket tanımlamak istediğinizi düşünün<ex:Hello> ve bunu bir vücutla aşağıdaki şekilde kullanmak istiyorsanız -

<ex:Hello>
   This is message body
</ex:Hello>

Etiketin gövdesini işlemek için yukarıdaki etiket kodunda aşağıdaki değişiklikleri yapalım -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   StringWriter sw = new StringWriter();
   public void doTag()
   
   throws JspException, IOException {
      getJspBody().invoke(sw);
      getJspContext().getOut().println(sw.toString());
   }
}

Burada, çağrıdan kaynaklanan çıktı ilk olarak bir StringWriteretiketle ilişkili JspWriter'a yazılmadan önce. TLD dosyasını aşağıdaki gibi değiştirmemiz gerekiyor -

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD with Body</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>scriptless</body-content>
   </tag>
</taglib>

Şimdi yukarıdaki etiketi uygun gövdeli aşağıdaki gibi adlandıralım -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello>
         This is message body
      </ex:Hello>
   </body>
</html>

Aşağıdaki sonucu alacaksınız -

This is message body

Özel Etiket Özellikleri

Özel etiketlerinizle birlikte çeşitli öznitelikleri kullanabilirsiniz. Bir öznitelik değerini kabul etmek için, özel bir etiket sınıfının şunu uygulaması gerekir:setter aşağıda gösterildiği gibi JavaBean ayarlayıcı yöntemleriyle aynı yöntemler -

package com.tutorialspoint;

import javax.servlet.jsp.tagext.*;
import javax.servlet.jsp.*;
import java.io.*;

public class HelloTag extends SimpleTagSupport {
   private String message;

   public void setMessage(String msg) {
      this.message = msg;
   }
   StringWriter sw = new StringWriter();
   public void doTag()
   
   throws JspException, IOException {
      if (message != null) {
         /* Use message from attribute */
         JspWriter out = getJspContext().getOut();
         out.println( message );
      } else {
         /* use message from the body */
         getJspBody().invoke(sw);
         getJspContext().getOut().println(sw.toString());
      }
   }
}

Özniteliğin adı "message", bu nedenle ayarlayıcı yöntemi setMessage(). Şimdi bu özniteliği TLD dosyasına ekleyelim.<attribute> aşağıdaki gibi eleman -

<taglib>
   <tlib-version>1.0</tlib-version>
   <jsp-version>2.0</jsp-version>
   <short-name>Example TLD with Body</short-name>
   
   <tag>
      <name>Hello</name>
      <tag-class>com.tutorialspoint.HelloTag</tag-class>
      <body-content>scriptless</body-content>
      
      <attribute>
         <name>message</name>
      </attribute>
   
   </tag>
</taglib>

JSP'yi mesaj niteliği ile aşağıdaki gibi takip edelim -

<%@ taglib prefix = "ex" uri = "WEB-INF/custom.tld"%>

<html>
   <head>
      <title>A sample custom tag</title>
   </head>
   
   <body>
      <ex:Hello message = "This is custom tag" />
   </body>
</html>

Bu, aşağıdaki sonucu verecektir -

This is custom tag

Bir öznitelik için aşağıdaki özellikleri eklemeyi düşünün -

S.No. Mülkiyet ve Amaç
1

name

Name öğesi, bir özniteliğin adını tanımlar. Her öznitelik adı, belirli bir etiket için benzersiz olmalıdır.

2

required

Bu, bu özelliğin gerekli olup olmadığını veya isteğe bağlı olduğunu belirtir. İsteğe bağlı olarak yanlış olur.

3

rtexprvalue

Bir etiket özelliği için çalışma zamanı ifade değerinin geçerli olup olmadığını bildirir

4

type

Bu niteliğin Java sınıf türünü tanımlar. Varsayılan olarak şu varsayılır:String

5

description

Bilgilendirici açıklama sağlanabilir.

6

fragment

Bu öznitelik değerinin bir JspFragment.

Aşağıda bir öznitelikle ilgili özellikleri belirtmek için örnek verilmiştir -

.....
   <attribute>
      <name>attribute_name</name>
      <required>false</required>
      <type>java.util.Date</type>
      <fragment>false</fragment>
   </attribute>
.....

İki özellik kullanıyorsanız, TLD'nizi aşağıdaki gibi değiştirebilirsiniz -

.....
   <attribute>
      <name>attribute_name1</name>
      <required>false</required>
      <type>java.util.Boolean</type>
      <fragment>false</fragment>
   </attribute>
   
   <attribute>
      <name>attribute_name2</name>
      <required>true</required>
      <type>java.util.Date</type>
   </attribute>
.....