안녕하세요. 😀 오늘은 JavaScript와 jQuery를 활용하여 HTML FORM TAG에 있는 데이터를 JSP 파일로 보내는 방법에 대해 포스팅해보도록 하겠습니다.
HTML FORM TAG의 경우 [HTML]FORM TAG편에서 포스팅 하였습니다. FORM TAG를 처음 보신다면 참고하고 오시면 좋을듯 해요 ㅎㅎ 😃
JavaScript와 jQuery를 처음 들어보신다면 [js, jQuery]JavaScript, jQuery 기초편에서 기초내용을 포스팅 하였으니 참고하고 오시면 좋을 듯 합니다 ㅎㅎ 😃
formtagpractice.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>FORM TAG 연습</title>
<script type="text/javascript">
function moveData(){
var getDataForm=window.document.getData;
console.log("window.document.getData >>> : "+getDataForm);
console.log("typeof(window.document.getData) >>> : "+typeof(getDataForm));
var getDataForm_1=window.document.getElementById("getDate");
console.log("window.document.getElementById :: getDate >>> : "+getDataForm_1);
console.log("typeof() :: window.document.getElementById :: getDate >>> : "+typeof(getDataForm_1));
var getDataForm_2=window.document.forms[0];
console.log("window.document.forms[0] >>> : "+getDataForm_2);
console.log("typeof(window.document.forms[0]) >>> : "+typeof(getDataForm_2));
var getInputtag=window.document.forms[0].elements[0];
console.log("window.document.forms[0].elements[0] >>> : "+getInputtag);
console.log("typeof(window.document.forms[0].elements[0]) >>> : "+typeof(getInputtag));
var input_mname=window.document.forms[0].elements[0].value;
console.log("window.document.forms[0].elements[0].value >>> : "+input_mname);
console.log("typeof() :: window.document.forms[0].elements[0].value >>> : "+typeof(input_mname));
var input_mname_2=document.getElementsByTagName("input")[0].value;
console.log("document.getElementsByTagName :: input :: [0].value >>> : "+input_mname_2);
console.log("typeof() :: document.getElementsByTagName :: input :: [0].value >>> : "+typeof(input_mname_2));
getDataForm_2.action="/firstWeb/getData/formtagpracticejsp.jsp"
getDataForm_2.method="GET"
getDataForm_2.submit();
}
</script>
</head>
<body>
<h3>FORM TAG 연습</h3>
<hr>
<br>
<form name="getDataa" id="getDate" >
이름 : <input type="text" name="mname" id="mname"><br>
주소 : <input type="text" name="maddr" id="maddr"><br>
<input type="button" value="전송" onclick="moveData()">
</form>
<form>
</form>
</body>
</html>
formtagpractice.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>FORM TAG 연습</title>
</head>
<body>
<h3>FORM TAG 연습 :: JSP에 넘어온 데이터 보기</h3>
<%
String name=request.getParameter("mname");
String addr=request.getParameter("maddr");
out.println("formtagpractice.html에서 받아온 이름 >>> : "+name+"<br>");
out.println("formtagpractice.html에서 받아온 주소 >>> : "+addr);
%>
</body>
</html>
jsp 파일 :: 주소표시줄 및 화면
✔ 주소표시줄
http://컴퓨터주소:포트번호/firstWeb/getData/formtagpracticejsp.jsp?mname=%ED%95%98%EC%9D%B4&maddr=%EB%B2%A8%EB%A1%9C%EA%B7%B8
✔ 화면
chrome 개발자도구 :: console 출력 결과
window.document.getData >>> : [object HTMLFormElement]
typeof(window.document.getData) >>> : object
window.document.getElementById :: getDate >>> : [object HTMLFormElement]
typeof() :: window.document.getElementById :: getDate >>> : object
window.document.forms[0] >>> : [object HTMLFormElement]
typeof(window.document.forms[0]) >>> : object
window.document.forms[0].elements[0] >>> : [object HTMLInputElement]
typeof(window.document.forms[0].elements[0]) >>> : object
window.document.forms[0].elements[0].value >>> : 하이
typeof() :: window.document.forms[0].elements[0].value >>> : string
document.getElementsByTagName :: input :: [0].value >>> : 하이
typeof() :: document.getElementsByTagName :: input :: [0].value >>> : string
eclipse :: Outline
출력 결과를 이해하기 위해서는 DOM Tree 구조를 이해하면 쉽게 이해할 수 있습니다.
DOM Tree구조는 [HTML]HTML 기초 1편에서 언급한 적이 있으니, 참고하시면 좋을 듯 합니다. 😃
window.document.태그이름
window.document.getElementById("아이디명")
window.document.forms[0]
window.documnet.forms[0].elements[0]
window.documnet.forms[0].elements[0]을 출력할 경우, form 배열중 가장 첫 번째 form의 가장 첫 번째 elements를 출력할 수 있습니다. 이 때의 경우, 해당 elements가 input태그이므로, object HTMLInputElement로 출력됩니다.
window.document.forms[0].elements[0].value
window.document.forms[0].elements[0].value로 출력할 경우, 해당 element의 value를 출력시킬 수 있습니다.
🤔 HTML 태그 아이디와 태그 이름은 무슨 차이인가요?
✔ 유의사항
http://컴퓨터주소:포트번호/firstWeb/getData/formtagpracticejsp.jsp?mname=%ED%95%98%EC%9D%B4&maddr=%EB%B2%A8%EB%A1%9C%EA%B7%B8
주소표시줄에서는 EBCDIC코드로 출력되는데, 이유는 FORM 태그에서 정보를 넘길 때, Default enctype이 application/x-www-form-urlencoded 이기 때문입니다.
주소표시줄에서 EBCDIC코드여도, JSP로 파일을 받았을 때, 한글로 잘 출력되는 것을 확인 할 수 있습니다.
1번째 formtagpractice.html
// 앞뒤 생략
<script type="text/javascript">
function moveData(){
var getDataForm_1 = window.document.getElementById("getData");
var input_mname_2=document.getElementsByTagName("input")[0].value;
input_mname_2='하이2';
console.log("input_mname_2 : "+input_mname_2);
getDataForm_1.action="/firstWeb/getData/formtagpracticejsp.jsp"
getDataForm_1.method="GET"
getDataForm_1.submit();
}
</script>
✔ 실제로 넘어가는 데이터
?mname=하이&maddr=벨로그
다음과 같이 변수로 설정한 값에 새로운 변수를 대입한다고 하여도, 실제로는 주소표시줄 ?뒤의 하이와 벨로그가 넘어가서 출력됩니다. (하이2가 출력되지 않습니다.)
2번째 : formtagpractice.html
// 앞뒤 생략
<script type="text/javascript">
function moveData(){
var getDataForm_1 = window.document.getElementById("getDate");
document.getElementsByTagName("input")[0].value="하이2";
/*
document.getElementById("mname").value = "하이3";
window.document.forms[0].elements[0].value="하이4";
getDataForm_1[0].value="하이5";
*/
getDataForm_1.action="/firstWeb/getData/formtagpracticejsp.jsp"
getDataForm_1.method="GET"
getDataForm_1.submit();
}
</script>
✔ 실제로 넘어가는 데이터
?mname=하이2&maddr=벨로그
다음과 같이 document 객체의 input 태그의 첫 번째 값을 직접 선언하는 경우, 이름에 어떤 값을 입력하여도, 넘어가는 데이터는 하이2가 됩니다.
document.getElementById("mname").value = "하이3";
window.document.forms[0].elements[0].value="하이4";
getDataForm_1[0].value="하이5";
위의 코드의 경우에도 실제로 넘어가는 데이터는 다음과 같이 넘어갑니다.
?mname=하이3&maddr=벨로그
?mname=하이4&maddr=벨로그
?mname=하이5&maddr=벨로그
즉, 실제 document 객체의 value를 수정하거나, 실제 보낼 객체의 하위 element의 value를 직접 수정하는 경우, 수정한 데이터가 jsp파일로 넘어가서 출력이 됩니다.
formtagpractice.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>FORM TAG 연습</title>
<script src="http://code.jquery.com/jquery-latest.min.js"></script>
<script type="text/javascript">
$("#getDate").ready(function(){
$("#btn").click(function(){
let mname=$("#mname").val();
console.log("mname >>> : "+mname);
// mname >>> 하이
$("#getDate").attr(
{
"action":"/firstWeb/getData/formtagpracticejsp.jsp",
"method":"GET"
}
).submit();
})
})
</script>
</head>
<body>
<h3>FORM TAG 연습</h3>
<hr>
<br>
<form name="getData" id="getDate" >
이름 : <input type="text" name="mname" id="mname"><br>
주소 : <input type="text" name="maddr" id="maddr"><br>
<input type="button" value="전송" id="btn">
</form>
<form>
</form>
</body>
</html>
✔ 실제로 넘어가는 데이터
?mname=하이&maddr=벨로그
JavaScript와 마찬가지로 jQuery를 사용하여 데이터를 넘길 수도 있습니다.
$("#태그아이디명").ready(function(){});
jQuery를 사용하여 form 태그 아이디인 getDate명을 찾은 다음, ready함수에 입력합니다.
$("#태그아이디명").click(function(){});
btn이라는 태그 아이디를 클릭할 경우, 해당 이벤트가 수행되는 함수 입니다.
$("#태그아이디명").attr({}).submit();
getDate라는 태그 아이디의 속성을 지정하여 해당 이벤트를 수행합니다.
.submit()
JavaScript와 마찬가지로, jQuery 또한, HTML의 Form Tag의 들어온 정보를 변형하여 JSP 파일에 보낼 수 있습니다.
formtagpractice.html
// 앞뒤 생략
$("#getDate").ready(function(){
$("#btn").click(function(){
$("#mname").val('하이5');
$("#getDate").attr(
{
"action":"/firstWeb/getData/formtagpracticejsp.jsp",
"method":"GET"
}
).submit();
})
})
</script>
✔ 실제로 넘어가는 데이터
?mname=하이5&maddr=벨로그
입력값으로 이름에 하이와 주소에 벨로그를 입력하여도 $("#mname").val('하이5'); 해당 명령어로 하이5라는 값을 jsp파일에 넘길 수도 있습니다.
$('input[name=mname]').val('하이6');
document.getData.mname.value='하이7';
위의 코드의 경우에도 실제로 넘어가는 데이터는 다음과 같이 넘어갑니다.
?mname=하이6&maddr=벨로그
?mname=하이7&maddr=벨로그
JavaScript와 jQuery의 이러한 특징을 이용하여, Form Tag에서 들어온 데이터를 그대로 JSP 파일에 보내줄 수도 있고, 상황에 따라 값을 바꿔서 JSP 파일로 보내줄 수도 있을 것입니다. 마지막으로, JSP 파일에서 데이터를 받는 request.getParameter 함수와 request.getParameterValues 함수를 간단히 소개하면서, 이번 포스팅을 마치도록 하겠습니다.
request는 내장 객체로 여러 함수를 이용하여 데이터를 요청하거나, 인코딩을 세팅하는 등의 작업을 수행할 수 있습니다.
// 앞 뒤 생략..
String name=request.getParameter("mname");
String addr=request.getParameter("maddr");
위의 코드가 있을 때, request.getParameter는 Form태그의 name 값을 가져옵니다.
한 편, 받아오는 name의 값이 하나가 아닐 경우, request.getParameterValues 명령어를 통해 배열로 받아올 수도 있습니다.
이 외에도 getParameterMap, getParameterNames 등, Enumeration으로 Return을 받을 수도 있고, Map으로 Returns을 받아 올 수 있습니다.
이상으로 [html, js, jQuery] FORM TAG 2편 포스팅을 마치도록 하겠습니다. 😃