Notice
Recent Posts
Recent Comments
Tags
- ASP.Net Core 404
- php 캐쉬제거
- jquery 바코드생성
- 맥 오라클설치
- ViewBag
- 말줄임표시
- jquery 바코드
- javascript redirection
- javascript 바코드스캔
- XSS PHP
- TempData
- 바코드 생성하기
- django 엑셀불러오기
- 404에러페이지
- XSS방어
- 바코드 스캔하기
- SSD 복사
- asp.net dropdownlist
- javascript 바코드 생성
- Mac Oracle
- 강제이동
- javascript 유효성체크
- 파일업로드 유효성체크
- 파일업로드 체크
- asp.net Select
- 타임피커
- 하드 윈도우 복사
- asp.net core Select
- ViewData
- 하드 마이그레이션
웹개발자의 기지개
[javascript] 자식창에서 POST 형태로 부모창으로 보내기 본문
window.open 형태로 부모창에서 자식창을 열어서 외부로 입력받는 폼값들을 만들었다.
문제는 자식창의 이러한 폼값들을 다시 원래의 부모창으로 POST 값들을 넘겨주어야 할때 생각해 보았다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
<script>
function sendPost() {
var form = document.createElement('form');
form.setAttribute('method', 'post');
form.setAttribute('action', "/부모창.asp");
document.charset = "utf-8";
var hiddenField = document.createElement('input');
hiddenField.setAttribute('type', 'hidden');
hiddenField.setAttribute('name', 'name');
hiddenField.setAttribute('value', '<%=name%>');
form.appendChild(hiddenField);
var hiddenField2 = document.createElement('input');
hiddenField2.setAttribute('type', 'hidden');
hiddenField2.setAttribute('name', 'hp');
hiddenField2.setAttribute('value', '<%=hp%>');
form.appendChild(hiddenField2);
var hiddenField3 = document.createElement('input');
hiddenField3.setAttribute('type', 'hidden');
hiddenField3.setAttribute('name', 'ver_number');
hiddenField3.setAttribute('value', '<%=ver_code%>');
form.appendChild(hiddenField3);
window.opener.document.body.appendChild(form);
form.submit();
}
sendPost();
self.close();
</script>
|
cs |
위의 소스는 자식창의 예제 소스이다.
핵심은 27라인이다.
window.opener 형태로 부모창을 나타내고 있다.
hidden input박스값을 3개 만들고 post 방식으로 값을 submit 시킨다.
다소 어렵지 않다.
문제는 크롬에서는 아주 잘 동작하는데, IE 에서는 위의 자식창이 닫히지도 않고 먹통이 되어 버린다.
이번에는 크롬과 IE 모두다 잘 작동되도록 소스를 고안하였다.
[ 부모창 ]
1
2
3
|
<script>
window.name = "parentPage";
</script>
|
cs |
parentPage 는 임의의 값으로 아무나 넣어도 된다.
[ 자식창 ]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<form name="fm" method="post">
<input type="hidden" name="name" value="<%=name%>">
<input type="hidden" name="hp" value="<%=hp%>">
<input type="hidden" name="ver_number" value="<%=ver_code%>">
</form>
<script>
function sendPost() {
document.fm.action = "/부모창.asp";
document.fm.target = opener.window.name;
document.fm.submit();
}
sendPost();
self.close();
</script>
|
cs |
의외로 무식하게 간단히 만들었더니 오히려 IE 에서도 크롬에서도 모두 잘 동작하였다. ~
핵심은 9라인이다.
document.fm.target = opener.window.name;
'javascript' 카테고리의 다른 글
[javascript] 여러개의 radio 버튼 체크했는지 확인하기 (0) | 2021.05.03 |
---|---|
[javascript] json 파싱하기 (0) | 2021.03.18 |
[javascript] 남은 시간, 타이머 (0) | 2020.12.03 |
[javascript] checkbox 전체선택, 전체해제, 선택한 checkbox 내용확인하기 1 (0) | 2020.10.27 |
[javascript] PDF 자동 로딩 - pdf.js 소스 연동하기 (모바일,pc 자동로딩) (1) | 2020.09.19 |
Comments