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...
コメント