Jsp自定義tag標簽

自定義tag標簽的好處

程序員可以自定義一些特定功能的標簽, 用來達到封裝代碼, 分工, 重用性等多種好處.

如何存放tag標簽

通常在web工程WEB-INF文件夾下創建tags文件夾來存放自定義的tag,如/WEB-INF/tags

tag標簽的語法

要知道怎樣定義tag標簽就需要知道tag標簽的基本屬性,例如:

<%@ tag body-content="empty" trimDirectiveWhitespaces="true" pageEncoding="UTF-8"%>

通常我們在.tag文件的開頭加上以上的代碼來告訴jsp容器這是一個tag標記文件。
body-content有以下三種屬性:

  1. empty:這個是一個空標記.
  2. scriptless:標記主體可以有內容, 并且jsp容器會去處理里面的jsp元素, 這些內容可以是文本, EL表達式, 標準動作甚至另一個自定義標記.
  3. tagdependent:標記主體可以有內容, 而jsp容器會把它們當作純文件處理

trimDirectiveWhitespaces=“true”表示刪除多余的空行
pageEncoding=”UTF-8” 表示page的編碼格式

標記中也可以定義attribute,例如:

<%@ attribute name="x" required="true" rtexprvalue="true" %>
<%@ attribute name="y" required="true" rtexprvalue="true" %>

attribute的屬性介紹如下:

  1. name :這個attribute的名稱.
  2. required : true/false, 是否必須的.
  3. rtexprvalue : true/false, 這個attribute可否使用EL表達式, 否則為純文本.
  4. type : 設定這個attribute的類型, jsp容器會把結果自動轉換成這個類.

我們看一下index.jsp的代碼:

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib tagdir="/WEB-INF/tags/" prefix="yu" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>define tag</title>
</head>
<body>
<!-- test tag [body-content="empty"] -->
<yu:add x="1" y="2"/>

</body>
</html>

該index.jsp中引用了add.tag文件,看一下add.tag文件的定義:

<%@ tag body-content="empty" trimDirectiveWhitespaces="true" pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ attribute name="x" required="true" rtexprvalue="true" %>
<%@ attribute name="y" required="true" rtexprvalue="true" %>
<div>
<h4>The result of x+y is</h4> 
    result = ${x+y}
</div>

運行起來程序我們看看運行結果:

至此,基本上已經理解了tag文件的使用了吧,那我們做進一步的學習。繼續編寫index.jsp代碼,來驗證body-content=”scriptless”的tag文件:

1 <!-- test tag [body-content="scriptless"] -->
2 <yu:scriptless_tag>
3 This tag's body-content is [scriptless], let's have a test, i'm here.<br/>
4 <label>contextPath:<label/> ${pageContext.request.contextPath}
5 </yu:scriptless_tag>

那我們來看一下scriptless_tag.tag文件的定義:

1 <%@ tag body-content="scriptless" trimDirectiveWhitespaces="true" pageEncoding="UTF-8"%>
2 <div style="background-color: red; width=auto">my backgroud color is red</div>
3 <jsp:doBody></jsp:doBody>
4 <div style="background-color: blue; width=70px;">my backgroud color is blue</div>

細心的朋友發現這里面多了一個<\jsp:doBody>標簽,該標簽的作用就是講index.jsp中該標記文件標記的主體顯示在該處,來看一下程序運行結果吧,一目了然:

在index.jsp文件中scriptless_tag標簽標記的主體顯示在了紅色背景和藍色背景之間,并且將代碼${pageContext.request.contextPath}解析成了 /yuTestTag

繼續編寫index.jsp代碼,來驗證body-content=”tagindependent”的tag文件:

1 <!-- test tag [body-content="tagindependent"] -->
2 <yu:tagdependent_tag>
3 This tag's body-content is [tagindependent], let's have a test, i'm here.
4 <label>contextPath:<label/> ${pageContext.request.contextPath}
5 </yu:tagdependent_tag>

scriptless_tag.tag文件的定義和scriptless_tag.tag的內容基本一樣:

1 <%@ tag body-content="tagdependent" trimDirectiveWhitespaces="true" language="java" pageEncoding="UTF-8"%>
2 <div style="background-color: red; width=auto">my backgroud color is red</div>
3 <jsp:doBody></jsp:doBody>
4 <div style="background-color: blue; width=70px;">my backgroud color is blue</div>

繼續看看運行結果:

代碼${pageContext.request.contextPath}沒有被解析,只是當做純文本文件
最后附上index.jsp的完整代碼:

 1 <%@ page language="java" contentType="text/html; charset=UTF-8" 
2  pageEncoding="UTF-8"%> 
3 <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> 
4 <%@ taglib tagdir="/WEB-INF/tags/" prefix="yu" %> 
5 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> 
6 <html> 
7 <head> 
8 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> 
9 <title>define tag</title>
10 </head>
11 <body>
12 <!-- test tag [body-content="empty"] -->
13 <yu:add x="1" y="2"/>
14 
15 <hr>
16 
17 <!-- test tag [body-content="scriptless"] -->
18 <yu:scriptless_tag>
19 This tag's body-content is [scriptless], let's have a test, i'm here.<br/>
20 <label>contextPath:<label/> ${pageContext.request.contextPath}
21 </yu:scriptless_tag>
22 
23 <hr>
24 
25 <!-- test tag [body-content="tagindependent"] -->
26 <yu:tagdependent_tag>
27  This tag's body-content is [tagindependent], let's have a test, i'm here.
28 <label>contextPath:<label/> ${pageContext.request.contextPath}
29 </yu:tagdependent_tag>
30 </body>
31 </html>
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評論 6 541
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,312評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,993評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,667評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,410評論 6 411
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,778評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,955評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,521評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,266評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,468評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,696評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,095評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,385評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,193評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,431評論 2 378

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,819評論 18 139
  • 前面講了servlet入門實踐現在開始介紹jsp入門實踐,開發環境的搭建請參考我前面的tomcat的文章,jsp入...
    伊豚wall閱讀 3,382評論 2 56
  • 1.學習內容 JSP技術入門和常用指令 JSP的內置對象&標簽介紹 EL表達式&EL的內置對象 2.JSP技術入門...
    WendyVIV閱讀 2,159評論 1 18
  • 1. Java基礎部分 基礎部分的順序:基本語法,類相關的語法,內部類的語法,繼承相關的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,733評論 18 399
  • 作用域:變量和函數的訪問范圍,作用域可以控制變量和函數的可見性和生命周期。JS中作用域分為兩種:全局作用域 和 局...
    IgorZhang閱讀 276評論 0 1