Maison >Java >javaDidacticiel >Présentation d'une explication détaillée de l'utilisation des balises personnalisées javaWeb

Présentation d'une explication détaillée de l'utilisation des balises personnalisées javaWeb

Y2J
Y2Joriginal
2017-05-02 13:49:061538parcourir

Cet article présente principalement l'utilisation des balises personnalisées javaWeb, et analyse les fonctions, les méthodes de définition et les principes d'exécution des balises personnalisées javaweb sous forme d'exemples. Les amis dans le besoin peuvent s'y référer

Cet article raconte. les exemples d'utilisation des étiquettes personnalisées javaWeb. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Création de balises personnalisées

Les balises personnalisées sont principalement utilisées pour supprimer le code Java .
Pour supprimer le code java de la page jsp, il vous suffit de suivre deux étapes :
-Écrire une classe Java qui hérite de TagSupport, remplacer la méthode doStartTag et écrire le code java de la page jsp dans le doStartTag méthode.
- Écrivez un fichier de descripteur de bibliothèque de balises (tld) et décrivez la balise personnalisée dans le fichier tld.
Après avoir effectué les opérations ci-dessus, vous pouvez importer et utiliser des balises personnalisées dans les pages JSP.

Classe de traitement des balises : HelloTag.java
Fichier de description des balises : hellotag.tld
Appel de page jsp : a52e5751f07545db7efce32c1729f60a Définir des expressions
[Facultatif] sur le web. Configurer le mappage hellotag.tld en XML

Processus de candidature :

index.jsp ==>[web.xml]==>hellotag.tld==> ;HelloTag.java

définit la classe de support des balises comme suit :

HelloTag.java

package china.hubei;
import java.io.IOException;
import javax.servlet.jsp.*;
import javax.servlet.jsp.tagext.TagSupport;
//自动定义标签
public class HelloTag extends TagSupport {
 public int doStartTag() throws JspException{
   PageContext pg=(PageContext)super.pageContext;
   JspWriter out=pg.getOut();
   try{
     out.println("hello world");
   }catch(IOException e){
   }
   return TagSupport.SKIP_BODY;
 }
}

Classe de description des balises, le suffixe est ​​.tld, Le contenu est conforme aux règles de syntaxe XML

hellotag.tld

<?xml version="1.0" encoding="UTF-8"?>
<taglib xmlns="http://java.sun.com/xml/ns/j2ee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee web-jsptaglibrary_2_0.xsd"
  version="2.0">
    <tlib-version>1.0</tlib-version> <!-- 标签库的版本 -->
    <short-name>dqtag</short-name><!-- 标签库在TLD中的描述名称 -->
    <tag>
      <name>hello</name>   <!-- 标签在jsp中使用名称 -->
      <tag-class>china.hubei.HelloTag</tag-class><!-- 标签指向的class文件 -->
      <body-content>empty</body-content><!-- 标签内容为空 -->
    </tag>
</taglib>

Utiliser des balises personnalisées sur la page jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page isELIgnored="false"%>
<%@taglib prefix="mytag" uri="/WEB-INF/hellotag.tld" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
 <title>标题</title>
  <!--
  <link rel="stylesheet" type="text/css" href="styles.css" rel="external nofollow" >
  -->
  <script language="javascript">
  </script>
 </head>
 <body>
  <h1><mytag:hello /></h1>
 </body>
</html>

L'effet d'exécution est comme suit :

Améliorations des balises personnalisées, déplacez le fichier de description de balise dans le fichier tld vers le fichier web.xml. Créez simplement un mappage pour le fichier tld dans le fichier web.xml.

Ajoutez le contenu suivant dans web.xml :

<jsp-config>
  <taglib>
    <taglib-uri>myhello</taglib-uri>
    <taglib-location>/WEB-INF/hellotag.tld</taglib-location>
  </taglib>
</jsp-config>

La balise d'introduction dans index.jsp est modifiée comme suit :

<%@taglib prefix="mytag" uri="myhello" %>

Remarques :

Principe d'exécution des balises personnalisées

Lorsque le moteur JSP rencontre une balise personnalisée, il créera d'abord une tag processeur Un objet d'instance de la classe, puis appelle ses méthodes dans l'ordre selon les règles de communication définies par la spécification JSP.

1. public void setPageContext(PageContext pc). Une fois que le moteur JSP a instancié le processeur de balises, il appellera la méthode setPageContext pour transmettre l'objet pageContext de la page JSP au processeur de balises. utilisez cet objet pageContext. Communiquez avec les pages JSP.
2. public void setParent(Tag t). Une fois la méthode setPageContext exécutée, le conteneur WEB appelle ensuite la méthode setParent pour transmettre la balise parent de la balise actuelle au processeur de balise actuelle. balise, elle est transmise à setParent. La valeur du paramètre de la méthode est nulle.
3. public int doStartTag(), après avoir appelé la méthode setPageContext et la méthode setParent, lorsque le conteneur WEB exécute la balise de début de la balise personnalisée, il appellera la méthode doStartTag du processeur de balise.
4. public int doEndTag(). Une fois que le conteneur WEB a exécuté le corps de la balise personnalisée, il exécutera ensuite la balise de fin de la balise personnalisée. À ce moment, le conteneur WEB appellera la méthode doEndTag. processeur de balises.
5. public void release(). Habituellement, après que le conteneur WEB ait exécuté la balise personnalisée, le processeur de balise résidera dans la mémoire et servira d'autres requêtes. Le conteneur Web n'appellera pas la méthode de publication tant que l'application Web ne sera pas arrêtée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn