[B -2-39] Ajax 댓글 처리 12

2019. 10. 9. 10:00Project B (SPMS)/Project B 파트5

반응형

자바스크립트 모듈 목록 처리

 

사전에 REST API 서버 호출해서 현재 댓글 목록 상태 확인

http://localhost/replies/pages/{댓글이 달린 게시글 번호}/1

http://localhost/replies/pages/{댓글이 달린 게시글 번호}/1.json

 

REST API 서버로부터 받은 순수 데이터들 목록을 알 수 있다.


 

/webapp/resources/js

reply.js

getList()

더보기
console.log("Reply Module........");

var replyService = (function() {

	function add(reply, callback, error) {
		console.log("add reply...............");

		$.ajax({
			type : 'post',
			url : '/replies/new',
			data : JSON.stringify(reply),
			contentType : "application/json; charset=utf-8",
			success : function(result, status, xhr) {
				if (callback) {
					callback(result);
				}
			},
			error : function(xhr, status, er) {
				if (error) {
					error(er);
				}
			}
		})
	}
	
	function getList(param, callback, error) {

	    var bno = param.bno;
	    var page = param.page || 1;
	    
	    $.getJSON("/replies/pages/" + bno + "/" + page + ".json",
	        function(data) {
	          if (callback) {
	            callback(data); // 댓글 목록만 가져오는 경우 
	          }
	        }).fail(function(xhr, status, err) {
		      if (error) {
		        error();
		      }
	        });
	}
	
	return {
		add : add,
		getList : getList
	};

})();

 

getJSON() 사용

reply.js 에서는 Ajax 호출을 담당하기때문에, 제이쿼리의 getJSON()을 이용해서 처리할 수 있다.

 

getList() 

param 이라는 객체를 통해서 필요한 파라미터를 전달받아 JSON 목록을 호출한다.

JSON 형태가 필요하므로 URL 호출 시 확장자를 .json 으로 요청한다.

 


views/board

get.jsp

getList()

더보기
<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt"%>

<%@ include file="../includes/header.jsp"%>
<div class="row">
	<div class="col-lg-12">
		<h1 class="page-header">게시판 조회</h1>
	</div>
	<!-- /.col-lg-12 -->
</div>
<!-- /.row -->
<div class="row">
	<div class="col-lg-12">
		<div class="panel panel-default">
			<div class="panel-heading">게시글 조회 페이지</div>
			<!-- /.panel-heading -->
			<div class="panel-body">
					<div class="form-group">
						<label>글 번호</label>
						<input class="form-control" name="bno" value='<c:out value="${board.bno }"/>' readonly="readonly">
					</div>
					<div class="form-group">
						<label>작성자</label>
						<input class="form-control" name="writer" value='<c:out value="${board.writer }"/>' readonly="readonly">
					</div>
					<div class="form-group">
						<label>제목</label>
						<input class="form-control" name="title" value='<c:out value="${board.title }"/>' readonly="readonly">
					</div>
					<div class="form-group">
						<label>내용</label>
						<textarea class="form-control" rows="10" name="content" readonly="readonly"><c:out value="${board.content}"/></textarea>
					</div>
					
					<button data-oper='modify' class="btn btn-default">수정</button>
					<button data-oper='list' class="btn btn-info">목록</button>
					
					<!-- operForm 시작 -->
					<form id='operForm' action="/board/modify" method="get">
						<input type='hidden' id='bno' name='bno' value='<c:out value="${board.bno}"/>'>
						<input type='hidden' name='pageNum' value='<c:out value="${cri.pageNum}"/>'>
						<input type='hidden' name='amount' value='<c:out value="${cri.amount}"/>'>
						
						<!-- Criteria의 키워드와 타입에 대한 처리 시작 -->
						<input type='hidden' name='keyword' value='<c:out value="${cri.keyword}"/>'>
						<input type='hidden' name='type' value='<c:out value="${cri.type}"/>'> 
						<!-- Criteria의 키워드와 타입에 대한 처리 종료 -->
					</form>
					<!-- operForm 종료 -->
			</div>
			<!-- /.panel-body -->
		</div>
		<!-- /.panel -->
	</div>
	<!-- /.col-lg-12 -->
</div>
<!-- /.row -->
</div>

<script type="text/javascript">
$(document).ready(function() {

  var operForm = $("#operForm"); 

  $("button[data-oper='modify']").on("click", function(e){

    operForm.attr("action","/board/modify").submit();

  });

  $("button[data-oper='list']").on("click", function(e){

    operForm.find("#bno").remove();
    operForm.attr("action","/board/list")
    operForm.submit();

  });
});
</script>

<script type="text/javascript" src="/resources/js/reply.js"></script>

<script>
	console.log("===============");
	console.log("JS TEST");
	
	var bnoValue = '<c:out value="${board.bno}"/>';
	/* 댓글 등록 처리 시작 */
	/* 
	// for replyService add test
	replyService.add(
    	{
    		reply:"JS Test", 
    		replyer:"tester", 
    		bno:bnoValue
    	},
	    function(result){
	      alert("RESULT : " + result);
	    }
	);
	 */
	/* 댓글 등록 처리 끝 */

	/* 댓글 목록 처리 시작 */
	replyService.getList({bno:bnoValue, page:1}, function(list){
	  for(var i = 0, len = list.length||0; i < len; i++ ){
	    console.log(list[i]);
	  }
	});
	/* 댓글 목록 처리 끝 */
	
</script>

<!-- /#page-wrapper -->
<%@ include file="../includes/footer.jsp"%>

댓글 등록과 마찬가지로 해당 게시글의 모든 댓글을 갖고오는지 확인하는 코드를 작성

 


댓글 목록 테스트 결과 

 

브라우저상의 개발자 도구 화면

 

댓글 목록을 제대로 갖고오는 것을 알 수 있다.

반응형

'Project B (SPMS) > Project B 파트5' 카테고리의 다른 글

[B -2-41] Ajax 댓글 처리 14  (0) 2019.10.09
[B -2-40] Ajax 댓글 처리 13  (0) 2019.10.09
[B -2-38] Ajax 댓글 처리 11  (0) 2019.10.09
[B -2-37] Ajax 댓글 처리 10  (0) 2019.10.08
[B -2-36] Ajax 댓글 처리 9  (0) 2019.10.08