메뉴 건너뛰기

조회 수 1617 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

<DIV> 태그를 잘 이용하면 특정 DIV 영역만 인쇄할 수가 있다. 이제부터 그 방법을 알아 보도록 하자.

인터넷 익스플로러는 window.onbeforeprint와 window.onafterprint 이벤트 핸들러를 지원하는데, 이들은 인쇄 전과 후의 웹 페이지 내용을 변경할 수 있도록 도와준다. 이 기능을 이용하여 특정 DIV 영역은 보이게 하고 나머지 영역은 숨길 수가 있다. (불행히 넷스케이프는 이 이벤트 핸들러를 지원하지 않는다. 하지만 여기서는 약간의 제약이 있긴 하지만 넷스케이프에서도 약간의 보이기 속성을 조절하여 비슷하게 구현해 보기로 한다.)

실제 코드를 실펴 보도록 하자.


<HTML>
<HEAD>
<STYLE>
DIV { position: relative; }
</STYLE>
<SCRIPT>
var div2print;


function printDiv (id) {
  if (document.all && window.print) {
    div2print = document.all[id];
    window.onbeforeprint = hideDivs;
    window.onafterprint = showDivs;
    window.print();
  } else if (document.layers) {
    div2print = document[id];
    hideDivs();
    //window.print();
  } 
}

function hideDivs () {
  if (document.all) {
    var divs = document.all.tags('DIV');
    for (var d = 0; d < divs.length; d++)
      if (divs[d] != div2print) {
        divs[d].style.display = 'none';
      }
  } else if (document.layers) {
    for (var l = 0; l < document.layers.length; l++)
      if (document.layers[l] != div2print)
        document.layers[l].visibility = 'hide';

  }
}


function showDivs () {
  var divs = document.all.tags('DIV');
  for (var d = 0; d < divs.length; d++)
    divs[d].style.display = 'block';
}
</SCRIPT>
</HEAD>
<BODY>

 

<DIV>
<FORM>
<SELECT NAME="divSelect">
<OPTION value="d1">첫 번째 영역만 인쇄
<OPTION value="d2">두 번째 영역만 인쇄
<OPTION value="d3">세 번째 영역만 인쇄
</SELECT>
<!-- <INPUT TYPE="button" ONCLICK="var s = this.form.divSelect; var divID = s.options[s.selectedIndex].text; printDiv(divID);"
         VALUE="특정 부분 인쇄">-->
<INPUT TYPE="button" ONCLICK="var s = this.form.divSelect; var divID = s.options[s.selectedIndex].value; printDiv(divID);"
         VALUE="특정 부분 인쇄">
</FORM>
</DIV>
<DIV ID="d1"><b>[첫 번째 영역]</b><br>첫 번째 영역입니다!<br><br></DIV>
<DIV ID="d2"><b>[두 번째 영역]</b><br>두 번째 영역입니다!<br>두 번째 영역을 선택하여 인쇄해 보세요!<br><br></DIV>
<DIV ID="d3"><b>[세 번째 영역]</b><br>세 번째 영역입니다!<br>세 번째 영역을 선택하여 인쇄해 보세요!<br>From 코리아인터넷닷컴</DIV>
</BODY>
</HTML>


List of Articles
번호 제목 날짜 조회 수
27 현재 날짜, 시간 ( Month + 1 에 대해서 ) 2021.03.25 231
26 자바스크립트에서 이벤트 중단 하는 방법 2021.03.25 339
25 default 매개변수(매개변수 기본값) 2021.03.26 218
24 페이지 이동 2021.03.26 201
23 DTREE 트리구조 만들기 file 2021.03.26 899
22 getYear(); 크롬, 파이어폭스 에서 제대로 작동 안하는 문제 2021.03.26 204
21 opener 값전달, 함수실행.(자식창에서 부모창으로 값전달, 함수실행) 2021.03.26 1463
20 split, join, replace, replace_all 2021.03.26 232
19 utf-8일때 alert 한글 깨짐 해결 2021.03.26 3606
18 자주쓰는 것들 2021.03.26 257
17 ajax 사용시 Internal Sever Error 뜨는 경우 2021.03.26 985
16 폼안에 태그명, 함수명 같을때 오류 2021.03.26 227
15 팝업창 맨위로 올라오게 하기 2021.03.26 911
14 3자리 마다 쉼표만 찍어주는 number_format 함수 2021.03.26 243
13 날짜 계산하기 (년/월/일 더하기, 빼기) 2021.08.20 2383
12 Date 객체로 원하는 날짜, 시간 표현하기 2021.08.20 244
11 월의 마지막 날짜 계산하기 2021.08.20 264
10 날짜 계산 (Date) 마지막 날짜(말일)/윤달/윤년 처리하기 2021.08.20 1591
9 시간 계산하기 (시/분/초/ 더하기, 빼기) 2021.08.20 1738
8 대소문자 변경 (대문자를 소문자로, 소문자를 대문자로) 2021.08.20 276
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved