[๊ตฌ๋””์•„์นด๋ฐ๋ฏธ IT๊ตญ๋น„์ง€์›] ์นดํ…Œ๊ณ ๋ฆฌ๋ณ„ ํšŒ์›์ „์šฉ ๊ฒŒ์‹œํŒ ํ”„๋กœ์ ํŠธ๋ฅผ ๋งˆ๋ฌด๋ฆฌํ–ˆ๋‹ค. ๊ฒŒ์‹œ๊ธ€ ์ถ”๊ฐ€/์ˆ˜์ •/์‚ญ์ œ ๊ธฐ๋Šฅ๊ณผ ๋Œ“๊ธ€ ์ˆ˜์ •/์‚ญ์ œ ๊ธฐ๋Šฅ์„ ์ถ”๊ฐ€ํ•˜๊ณ  CSS ์ž‘์—…์„ ํ–ˆ๋‹ค. ๋˜ํ•œ, ์ด์ „/๋‹ค์Œ ๋ฒ„ํŠผ๋งŒ ์žˆ๋˜ ๊ธฐ์กด ํŽ˜์ด์ง•์„ ์ค‘๊ฐ„์— ํŽ˜์ด์ง€๋„˜๋ฒ„๋ฅผ ์„ ํƒํ•  ์ˆ˜ ์žˆ๋„๋ก ๋ณ€๊ฒฝํ•ด๋ณด์•˜๋‹ค!


๐Ÿ’ก ์นดํ…Œ๊ณ ๋ฆฌ๋ณ„ ํšŒ์›์ „์šฉ ๊ฒŒ์‹œํŒ ํ”„๋กœ์ ํŠธ

๐Ÿ“Œ ์ž‘์—…๊ธฐ๋ก

โœ” ๊ฒŒ์‹œ๊ธ€

  • ๊ฒŒ์‹œ๊ธ€ ์ถ”๊ฐ€
    insertBoardForm.jsp
    insertBoardAction.jsp
    ๐Ÿ‘‰ ํšŒ์›๋งŒ ๊ฐ€๋Šฅ

  • ๊ฒŒ์‹œ๊ธ€ ์ˆ˜์ •/์‚ญ์ œ
    updateBoardForm.jsp
    updateBoardAction.jsp
    deleteBoardAction.jsp
    ๐Ÿ‘‰ ํšŒ์› ๋ณธ์ธ๋งŒ ๊ฐ€๋Šฅ

โœ” ๋Œ“๊ธ€

  • ๋Œ“๊ธ€ ์ˆ˜์ •/์‚ญ์ œ
    updateCommentForm.jsp
    updateCommentAction.jsp
    deleteCommentAction.jsp
    ๐Ÿ‘‰ ํšŒ์› ๋ณธ์ธ๋งŒ ๊ฐ€๋Šฅ
  • comment ํ…Œ์ด๋ธ” board_no ์™ธ๋ž˜ํ‚ค cascade ์„ค์ •

โœ” CSS

  • Bootswatch
    Bootswatch์˜ Sketchy ํ…Œ๋งˆ๋ฅผ ์ด์šฉํ–ˆ๋‹ค.

๐Ÿ’ก ์ค‘๊ฐ„ ํŽ˜์ด์ง•

์ด์ „/๋‹ค์Œ ๋ฒ„ํŠผ๋งŒ ์žˆ์—ˆ๋˜ ๊ธฐ์กด ํŽ˜์ด์ง•์—์„œ ์ด์ „/๋‹ค์Œ ์‚ฌ์ด์— ํŽ˜์ด์ง€๋ฅผ ์ง์ ‘ ์„ ํƒํ•  ์ˆ˜ ์žˆ๋„๋ก ํŽ˜์ด์ง€๋„˜๋ฒ„๊ฐ€ ์ถ”๊ฐ€๋œ ์ค‘๊ฐ„ ํŽ˜์ด์ง•์œผ๋กœ ์—…๊ทธ๋ ˆ์ด๋“œํ•ด๋ณด์•˜๋‹ค!

์ถ”๊ฐ€๋˜๋Š” ๋ณ€์ˆ˜๋Š” ๋‹ค์Œ๊ณผ ๊ฐ™๋‹ค.

  • int pageLength : ํŽ˜์ด์ง€ ํ•œ ๋ฌถ์Œ(๋ธ”๋ก)์— ํŽ˜์ด์ง€๊ฐ€ ๋ช‡ ๊ฐœ์”ฉ ๋“ค์–ด๊ฐ€๋„๋ก ํ• ์ง€ ์ง€์ •ํ•œ๋‹ค.
  • int currentBlock : ํ˜„์žฌ ๋ช‡ ๋ฒˆ์งธ ํŽ˜์ด์ง€ ๋ธ”๋ก์ธ์ง€
  • int startPage : ํ˜„์žฌ ํŽ˜์ด์ง€ ๋ธ”๋ก์˜ ์‹œ์ž‘ ํŽ˜์ด์ง€
  • int endPage : ํ˜„์žฌ ํŽ˜์ด์ง€ ๋ธ”๋ก์˜ ๋ ํŽ˜์ด์ง€

currentBolock์€ ๋ฐ˜๋“œ์‹œ ์ถ”๊ฐ€ํ•ด์•ผ๋˜๋Š” ๋ณ€์ˆ˜๋Š” ์•„๋‹ˆ๋‹ค.

int pageLength = 10;
int currentBlock = currentPage / pageLength;
	if(currentPage % pageLength != 0) {
		currentBlock = currentBlock + 1;
	}
int startPage = (currentBlock - 1) * pageLength + 1; 
int endPage = startPage + pageLength - 1 ;
	if(endPage > totalPage) {
		endPage = totalPage;
	}

ํŽ˜์ด์ง€ ์ถœ๋ ฅ ์‹œ

<!------- ํŽ˜์ด์ง• ์‹œ์ž‘ ------->
<div>
	<ul class="pagination" style="justify-content : center;">
		<%
			if(startPage == 1) {
		%>
				<li class="page-item disabled">
					<a class="page-link" href="#">&laquo;</a>
				</li>
		<%
			} else {
		%>
				<li class="page-item">
					<a class="page-link" href="<%=request.getContextPath()%>/home.jsp?currentPage=<%=startPage - 1%>&rowPerPage=<%=rowPerPage%>&localName=<%=localName%>">&laquo;</a>
				</li>
		<%
			}
		%>
		<%
			for(int i = startPage; i <= endPage; i++) {
		%>
				<li class="page-item <%if(i == currentPage){%> active <%}%>">
					<a class="page-link" href="<%=request.getContextPath()%>/home.jsp?currentPage=<%=i%>&rowPerPage=<%=rowPerPage%>&localName=<%=localName%>">
						<%=i%>
					</a>
				</li>
		<%
			}
		%>
		<%
			if(totalPage == endPage) {
		%>
				<li class="page-item disabled">
					<a class="page-link" href="#">&raquo;</a>
				</li>
		<%
			} else {
		%>
				<li class="page-item">
					<a class="page-link" href="<%=request.getContextPath()%>/home.jsp?currentPage=<%=endPage + 1%>&rowPerPage=<%=rowPerPage%>&localName=<%=localName%>">&raquo;</a>
				</li>
		<%
			}
		%>
	</ul>
</div>
<!------- ํŽ˜์ด์ง• ๋ ------->

๐Ÿ“ ๊ฒฐ๊ณผ




profile
ํ•˜๋ฃจ ํ•œ๊ฑธ์Œ์”ฉ๐Ÿ’ช ์ดˆ๋ณด ๊ฐœ๋ฐœ์ž ๋„์ „๊ธฐ ๐ŸŒฑ๐Ÿ’ป

0๊ฐœ์˜ ๋Œ“๊ธ€