SLOOP

window.print() div 를 이용한 부분인쇄

· 18년 전 · 6134
보통 print 함수 사용시 원하지 않는 부분이 출력되는데 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>
<p><font size="2"><b>아래 선택 상자에서 원하는 인쇄 영역을 선택한 다음 "특정 부분 인쇄" 버튼을 클릭하세요!</b></font></p>
<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].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>
</DIV></BODY>
</HTML>
 
네이버 지식인 에서 발취 저작권 문제시 삭제 하겠습니다.
[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
18년 전 조회 2,063
18년 전 조회 3,092
18년 전 조회 2,379
18년 전 조회 2,396
18년 전 조회 2,072
18년 전 조회 2,444
18년 전 조회 3,182
18년 전 조회 4,117
18년 전 조회 3,394
18년 전 조회 2,034
18년 전 조회 1,977
18년 전 조회 2,884
18년 전 조회 1,680
18년 전 조회 2,036
18년 전 조회 2,325
18년 전 조회 2,192
18년 전 조회 2,291
18년 전 조회 4,051
18년 전 조회 1,807
18년 전 조회 4,408
18년 전 조회 2,946
18년 전 조회 2,252
18년 전 조회 3,293
18년 전 조회 2,922
18년 전 조회 2,858
18년 전 조회 5,650
18년 전 조회 2,318
18년 전 조회 3,439
18년 전 조회 3,350
18년 전 조회 3,732
18년 전 조회 3,285
18년 전 조회 2,462
18년 전 조회 2,117
18년 전 조회 2,571
18년 전 조회 6,135
18년 전 조회 2,762
18년 전 조회 4,560
18년 전 조회 2,059
18년 전 조회 1만
18년 전 조회 2,504
18년 전 조회 1,568
18년 전 조회 3,010
18년 전 조회 2,947
18년 전 조회 2,842
18년 전 조회 2,157
18년 전 조회 2,340
18년 전 조회 2,887
18년 전 조회 2,981
18년 전 조회 4,149
18년 전 조회 6,135
18년 전 조회 2,073
18년 전 조회 2,208
18년 전 조회 1,916
18년 전 조회 1,675
18년 전 조회 2,654
18년 전 조회 1,702
18년 전 조회 1,574
18년 전 조회 4,757
18년 전 조회 1,810
18년 전 조회 1,864
18년 전 조회 1,871
18년 전 조회 1,989
18년 전 조회 3,646
18년 전 조회 1,670
18년 전 조회 1,546
18년 전 조회 1,375
18년 전 조회 1,878
18년 전 조회 1,927
18년 전 조회 3,670
18년 전 조회 2,000
18년 전 조회 3,139
18년 전 조회 4,758
18년 전 조회 2,892
18년 전 조회 8,067
18년 전 조회 4,077
18년 전 조회 2,767
18년 전 조회 1,540
18년 전 조회 2,646
18년 전 조회 5,061
18년 전 조회 5,239
18년 전 조회 2,116
18년 전 조회 4,372
18년 전 조회 4,116
18년 전 조회 4,171
18년 전 조회 2,290
18년 전 조회 4,216
18년 전 조회 2,194
18년 전 조회 3,300
18년 전 조회 4,938
18년 전 조회 1,973
18년 전 조회 3,436
18년 전 조회 1,662
18년 전 조회 2,762
18년 전 조회 1,690
18년 전 조회 2,737
18년 전 조회 2,574
18년 전 조회 1,577
18년 전 조회 1,516
18년 전 조회 1,760
18년 전 조회 2,263