JSP & Servletで作る英和辞書アプリ(JSTL版)

JSP&Servlet

7回に分けて連載してきた英語辞書アプリ。今回は応用的な内容としてJSTL(Java ServerPages Standard Tag library)を使ってjspからスクリプティング要素削除したものを作成してみよう。

JSTL配置

下記の記事通りに2つのjarファイルをWEB-INF/libの中にコピペで貼り付ける

以下のように2つのファイルを配置できればOK

main.jspの修正

以下のようにmain.jspを修正する。

○WEB-INF/view/main.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>EJWord</title>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css" integrity="sha384-HSMxcRTRxnN+Bdg0JdbxYKrThecOKuH5zCYotlSAcp1+c8xmyTe9GYg1l9a69psu" crossorigin="anonymous">
<link rel="stylesheet" href="css/main.css">
</head>
<body>
<div class="container">
<form action="/ejword/main" method="get" class="form-inline">
<input type="text" name="searchWord" value="${ ejw.searchWord}" class="form-control" placeholder="検索後を入力" required>
<select name="mode" class="form-control">
<option value="startsWith" ${ejw.mode eq "startsWith" ? "selected":"" }>で始まる</option>
<option value="contains" ${ejw.mode eq "contains" ? "selected":"" }>含む</option>
<option value="endsWith" ${ejw.mode eq "endsWith" ? "selected":"" }>で終わる</option>
<option value="match" ${ejw.mode eq "match" ? "selected":"" }>一致する</option>
</select>
<button type="submit" class="btn btn-primary">検索</button>
</form>
<c:if test="${not empty ejw.searchWord and empty ejw.list }">
<p>1件も一致しませんでした</p>
</c:if>
<c:if test="${not empty ejw.list }">
	<c:if test="${ejw.total le ejw.limit }">
		<p>全${ejw.total }件</p>
	</c:if>
	<c:if test="${ejw.total gt ejw.limit }">
		<p>全${ejw.total }件中
		${(ejw.pageNo-1)*ejw.limit+1}~
		${ejw.pageNo*ejw.limit gt ejw.total ? ejw.total:ejw.pageNo*ejw.limit }
		件を表示
		</p>
		<ul class="pager">
		<c:if test="${ejw.pageNo gt 1 }">
			<li><a href="/ejword/main?searchWord=${ejw.searchWord }&mode=${ejw.mode }&page=${ejw.pageNo-1}">←前へ</a></li>
		</c:if>
		<c:if test="${ejw.pageNo * ejw.limit lt ejw.total }">
			<li><a href="/ejword/main?searchWord=${ejw.searchWord }&mode=${ejw.mode }&page=${ejw.pageNo+1}">次へ→</a></li>
		</c:if>
		</ul>
	</c:if>
	<table class="table table-borderd table-striped">
		<c:forEach var="w" items="${ejw.list}">
			<tr><th>${w.title }</th><td>${w.body }</td></tr>
		</c:forEach>
	</table>
	<c:if test="${not empty ejw.pager }">
	<div class='paginationBox'>
		<ul class='pagination'>
		<c:forEach var="row" items="${ejw.pager }">
			<li class="${row[0] }">
			<a href="/ejword/main?searchWord=${ejw.searchWord}&mode=${ejw.mode}&page=${row[1]}">${row[2]}</a>
			</li>
		</c:forEach>
		</ul>
	</div>
	</c:if>
</c:if>
</div>
<footer>
© 2022 Joytas.net
</footer>
</body>
</html>


完成

スクリプティング要素が減少し、記述量も減っている。
学習コストもかかるが、EL式やJSTLも少しずつ慣れていこう。

参考

7.ELとJSTLで豊かな表現ができるようになる | セイコンサルティンググループ
前回は、JavaBeansについて学びました。今回は、ELとJSTLについて学びます。ELではオブジェクトのプロパティが表示できるようになります。さらに、JSTLのCタグで制御文を書くと、条件分岐や繰り返しが書けます。さらに、JSTLのfm...

コメント

タイトルとURLをコピーしました