Bagaimana cara menggunakan HTML untuk mencetak header dan footer pada setiap halaman dokumen yang dicetak?

516

Apakah mungkin untuk mencetak halaman HTML dengan header dan footer khusus pada setiap halaman yang dicetak?

Saya ingin menambahkan kata "UNCLASSIFIED" di Red, Arial, ukuran 16pt ke atas dan bawah setiap halaman yang dicetak , terlepas dari kontennya.

Untuk memperjelas, jika dokumen dicetak ke 5 halaman, setiap halaman harus memiliki header dan footer kustom.

Adakah yang tahu apakah ini mungkin menggunakan HTML / CSS?

Nhan
sumber
3
Ini adalah pertanyaan yang saya coba jawab untuk waktu yang lama. Sepertinya kunci masalahnya adalah elemen css seperti halaman, pusat-tengah, konten, posisi: running (..). Bagaimana bisa terlihat jika browser sepenuhnya mendukung @ halaman: techrepublic.com/blog/webmaster/... alistapart.com/articles/boom alistapart.com/articles/building-books-with-css3 Beberapa masalah terbuka: code.google.com / p / chromium / issues / detail? id = 47277 bugs.webkit.org/show_bug.cgi?id=15548
Daniel
Saya telah memposting solusi yang kompatibel dengan Chrome di sini yang akan menambahkan tajuk yang sedang berjalan ke dokumen yang tidak mengandung terlalu banyak teks. Namun, tetap tidak ada solusi untuk catatan kaki.
DoctorDestructo
2
Solusi Combinative : keduanya pisition: fixeddan thead tbody tfootteknik memiliki kelemahan sehingga Anda harus menggabungkannya, baca lebih lanjut di sini .
Mohammad Musavi

Jawaban:

353

Jika Anda mengambil elemen yang Anda ingin menjadi footer dan mengaturnya menjadi posisi: tetap dan bawah: 0, ketika halaman mencetak akan mengulangi elemen itu di bagian bawah setiap halaman yang dicetak. Hal yang sama akan bekerja untuk elemen header, cukup atur top: 0 sebagai gantinya.

Sebagai contoh:

<div class="divFooter">UNCLASSIFIED</div>

CSS:

@media screen {
  div.divFooter {
    display: none;
  }
}
@media print {
  div.divFooter {
    position: fixed;
    bottom: 0;
  }
}
Infotekka
sumber
62
Tampaknya tidak berfungsi jika Anda memiliki elemen yang membentang dua halaman (pra dalam kasus saya) - catatan kaki akan ditimpa di atasnya.
Benjol
77
Sepertinya browser webkit tidak mendukung ini dengan benar. Koreksi saya jika saya salah!
Gregg Lind
61
Ini sepertinya tidak berulang di setiap halaman.
Tyson of the Northwest
24
Ini tidak berhasil untuk saya, saya menggunakan Chrome 15.0. Semua yang dilakukannya adalah mencetak elemen di mana ia akan berada di layar, misalnya di tengah halaman, jika itu tempat saya menggulir ke. Tentu tidak mencetak pada setiap halaman.
chharvey
11
Saya mengujinya di Firefox dan Chrome. Di Firefox solusi ini berfungsi, di Chrome tidak.
Jaro
131

Saya percaya jawaban yang benar adalah bahwa HTML 5 dan CSS3 tidak memiliki dukungan untuk mencetak header halaman dan footer di printmedia.

Dan sementara Anda mungkin dapat mensimulasikannya dengan:

  • meja
  • blok posisi tetap

mereka masing-masing memiliki bug yang mencegah mereka menjadi solusi umum yang ideal.

Ian Boyd
sumber
36
Jangan percaya jawaban yang lain. Mereka mungkin bekerja untuk kasus-kasus khusus tetapi secara umum akan rusak parah. Tidak ada solusi yang dapat diandalkan hingga kotak margin halaman diterapkan di browser utama. Lihat: en.wikipedia.org/wiki/…
user2847643
21
Sayangnya saya harus memperbaiki yang ini. Meskipun kami memiliki tahun 2018 ... mengapa hack tidak mereka memberi kita @footerdengan content:"stuff"atau sama.
Kai Noack
1
Sebenarnya ada spesifikasi dalam pembuatan di W3C untuk mengatasi skenario ini.
Mendy
Saya pikir ini adalah jawaban terbaik. Masalahnya adalah vendor browser. Anda dapat membuat PDF yang bagus di luar browser menggunakan CSS Paged Media dengan alat komersial seperti ini (dan ada yang lain): Antenna House antennahouse.com/formatter , Prince princexml.com .
markg
Saya menjadikan ini sebagai komentar, bukan jawaban, jadi tolong jangan pukul saya dengan "OP tidak bertanya ...". Satu kemungkinan adalah dengan menggunakan generator PDF yang memungkinkan Anda untuk mengatur header dan footer tetap dan membuat tampilan Anda ke dalam format ini ketika pengguna memutuskan mereka ingin "print preview" atau dokumen cetak. HTML untuk rendering layar dan layar tidak memiliki konsep halaman. PDF mungkin juga berarti format dokumen cetak (saya tahu, tidak) dan merupakan modalitas di mana header dan footer halaman relevan. NReco.PdfGenerator sangat terjangkau untuk keperluan bisnis atau gratis untuk dicoba.
Newclique
71

Saya hanya menghabiskan setengah hari saya dengan solusi yang benar-benar bekerja untuk saya dan saya pikir saya akan membagikan apa yang saya lakukan. Masalah dengan solusi di atas yang saya alami adalah bahwa semua elemen paragraf saya akan tumpang tindih dengan footer yang saya inginkan di bagian bawah halaman. Untuk menyiasatinya, saya menggunakan CSS berikut:

footer {
  font-size: 9px;
  color: #f00;
  text-align: center;
}

@page {
  size: A4;
  margin: 11mm 17mm 17mm 17mm;
}

@media print {
  footer {
    position: fixed;
    bottom: 0;
  }

  .content-block, p {
    page-break-inside: avoid;
  }

  html, body {
    width: 210mm;
    height: 297mm;
  }
}

The page-break-insideuntuk pdan content-blocksangat penting bagi saya. Setiap kali saya memiliki ppengikut h*, saya membungkus mereka berdua dalam div class = "content-block">untuk memastikan mereka tetap bersama dan tidak putus.

Saya berharap seseorang menemukan ini berguna karena butuh sekitar 3 jam untuk mencari tahu (Saya juga baru mengenal CSS / HTML, jadi begitulah ...)

EDIT

Per permintaan dalam komentar, saya menambahkan contoh dokumen HTML. Anda ingin menyalin ini ke file HTML, membukanya, dan kemudian memilih untuk mencetak halaman. Pratinjau cetak harus menunjukkan ini berfungsi. Ini berfungsi di Firefox dan IE pada akhirnya, tetapi Chrome membuat font cukup kecil untuk muat pada satu halaman, jadi itu tidak berfungsi di sana.

footer {
  font-size: 9px;
  color: #f00;
  text-align: center;
}

@page {
  size: A4;
  margin: 11mm 17mm 17mm 17mm;
}

@media print {
  footer {
    position: fixed;
    bottom: 0;
  }

  .content-block, p {
    page-break-inside: avoid;
  }

  html, body {
    width: 210mm;
    height: 297mm;
  }
}
<!DOCTYPE html>
<html>
  <head></head>
  <body>
    <h1>
      Example Document
    </h1>
    <div>
      <p>
        This is an example document that shows how to have a footer that repeats at the bottom of every page, but also isn't covered up by paragraph text.
      </p>
    </div>
    <div>
      <h3>
        Example Section I
      </h3>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc vestibulum metus sit amet urna lobortis sollicitudin. Nulla mattis purus porta lorem tempor, a cursus tellus facilisis. Aliquam pretium nibh vitae elit placerat vestibulum. Duis felis ipsum, consectetur id pellentesque in, porta sit amet sapien. Ut tristique enim sem, laoreet bibendum nisl fermentum vitae. Ut aliquet sem ac lorem malesuada sodales. Fusce iaculis ipsum ex, in mollis dolor dapibus sit amet. In convallis felis in orci fermentum gravida a vel orci. Sed tincidunt porta nibh sit amet varius. Donec et odio eget odio tempus auctor ac eget ex.
        
        Pellentesque vitae augue sed purus dictum ultricies at eu neque. Nullam ut mauris a purus tristique euismod. Sed elementum, leo id placerat congue, leo tellus pharetra orci, eget ultricies odio quam sit amet ipsum. Praesent feugiat, lorem at commodo egestas, felis ligula pharetra sapien, in placerat mauris nisi aliquet tortor. Quisque nibh lectus, laoreet vel mollis a, tincidunt vel ipsum. Sed blandit vehicula sollicitudin. Donec et sapien justo. Ut fermentum ipsum imperdiet diam condimentum, eget varius sapien dictum. Sed sed elit egestas libero maximus finibus eu eget massa.
        
        Duis finibus vestibulum finibus. Nunc lobortis lacus ut libero mattis tempor. Nulla a nunc at nisl elementum congue. Nunc eu consectetur mauris. Etiam non placerat massa. Etiam eu urna in metus tempus molestie sed eget diam. Nunc sem velit, elementum sit amet fringilla in, dictum sit amet sem. Quisque convallis faucibus purus dignissim dictum. Sed semper, mi vel accumsan sollicitudin, massa massa pellentesque justo, eget auctor sapien enim ac elit.
        
        Nullam turpis augue, lacinia ut libero ac, rhoncus bibendum ligula. Mauris ullamcorper maximus turpis, a consequat turpis bibendum sit amet. Nam vitae dui nec velit hendrerit faucibus. Vivamus nunc diam, porta tristique augue nec, dignissim venenatis felis. Proin mattis id risus in feugiat. Etiam cursus faucibus nisi. In in nisi ullamcorper, convallis lectus et, ornare nulla. Cras tristique nulla eros, non maximus odio imperdiet eu. Nullam egestas dignissim est, et fringilla odio pretium eleifend. Nullam tincidunt sapien fermentum, rhoncus risus ac, ullamcorper libero. Vestibulum bibendum molestie dui nec tincidunt. Mauris tempus, orci ut congue vulputate, erat orci aliquam orci, sed eleifend orci dui sed tellus. Pellentesque pellentesque massa vulputate urna pretium, consectetur pulvinar orci pulvinar.
        
        Donec aliquet imperdiet ex, et tincidunt risus convallis eget. Etiam eu fermentum lectus, molestie eleifend nisi. Orci varius natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Nullam dignissim, erat vitae congue molestie, ante urna sagittis est, et sagittis lacus risus vitae est. Sed elementum ipsum et pellentesque dignissim. Sed vehicula feugiat pretium. Donec ex lacus, dictum faucibus lectus sit amet, tempus hendrerit ante. Ut sollicitudin sodales metus, at placerat risus viverra ut.
        
        Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc vestibulum metus sit amet urna lobortis sollicitudin. Nulla mattis purus porta lorem tempor, a cursus tellus facilisis. Aliquam pretium nibh vitae elit placerat vestibulum. Duis felis ipsum, consectetur id pellentesque in, porta sit amet sapien. Ut tristique enim sem, laoreet bibendum nisl fermentum vitae. Ut aliquet sem ac lorem malesuada sodales. Fusce iaculis ipsum ex, in mollis dolor dapibus sit amet. In convallis felis in orci fermentum gravida a vel orci. Sed tincidunt porta nibh sit amet varius. Donec et odio eget odio tempus auctor ac eget ex.
        
        Duis finibus vestibulum finibus. Nunc lobortis lacus ut libero mattis tempor. Nulla a nunc at nisl elementum congue. Nunc eu consectetur mauris. Etiam non placerat massa. Etiam eu urna in metus tempus molestie sed eget diam. Nunc sem velit, elementum sit amet fringilla in, dictum sit amet sem. Quisque convallis faucibus purus dignissim dictum. Sed semper, mi vel accumsan sollicitudin, massa massa pellentesque justo, eget auctor sapien enim ac elit.
        
        Nullam turpis augue, lacinia ut libero ac, rhoncus bibendum ligula. Mauris ullamcorper maximus turpis, a consequat turpis bibendum sit amet. Nam vitae dui nec velit hendrerit faucibus. Vivamus nunc diam, porta tristique augue nec, dignissim venenatis felis. Proin mattis id risus in feugiat. Etiam cursus faucibus nisi. In in nisi ullamcorper, convallis lectus et, ornare nulla. Cras tristique nulla eros, non maximus odio imperdiet eu. Nullam egestas dignissim est, et fringilla odio pretium eleifend. Nullam tincidunt sapien fermentum, rhoncus risus ac, ullamcorper libero.
      </p>
    </div>
    <div class="content-block">
      <h3>Example Section II</h3>
      <p>
        Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nunc vestibulum metus sit amet urna lobortis sollicitudin. Nulla mattis purus porta lorem tempor, a cursus tellus facilisis. Aliquam pretium nibh vitae elit placerat vestibulum. Duis felis ipsum, consectetur id pellentesque in, porta sit amet sapien. Ut tristique enim sem, laoreet bibendum nisl fermentum vitae. Ut aliquet sem ac lorem malesuada sodales. Fusce iaculis ipsum ex, in mollis dolor dapibus sit amet. In convallis felis in orci fermentum gravida a vel orci. Sed tincidunt porta nibh sit amet varius. Donec et odio eget odio tempus auctor ac eget ex.
        
        Pellentesque vitae augue sed purus dictum ultricies at eu neque. Nullam ut mauris a purus tristique euismod. Sed elementum, leo id placerat congue, leo tellus pharetra orci, eget ultricies odio quam sit amet ipsum. Praesent feugiat, lorem at commodo egestas, felis ligula pharetra sapien, in placerat mauris nisi aliquet tortor. Quisque nibh lectus, laoreet vel mollis a, tincidunt vel ipsum. Sed blandit vehicula sollicitudin. Donec et sapien justo. Ut fermentum ipsum imperdiet diam condimentum, eget varius sapien dictum. Sed sed elit egestas libero maximus finibus eu eget massa.
      </p>
    </div>
    <footer>
      This is the text that goes at the bottom of every page.
    </footer>
  </body>
</html>

brittenb
sumber
1
Terima kasih untuk ini, saya hanya berharap ada contoh dokumen HTML dalam jawaban untuk membuatnya lebih mudah.
Eric Kigathi
2
@EricKigathi Tercatat Saya akan mencoba yang terbaik untuk menyiasatinya akhir pekan ini dan mengedit jawaban saya.
brittenb
2
@EricKigathi tidak memenuhi tenggat waktu akhir pekan saya, tetapi saya telah menambahkan contoh kode HTML. Semoga itu bisa membantu!
brittenb
Terima kasih @brittenb - sangat kami hargai, Anda dimaafkan karena melewatkan tenggat waktu; )
Eric Kigathi
3
tidak berfungsi untuk halaman kedua untuk tajuk. masih tumpang tindih
Fei Xue - MSFT
17

Saya telah mencari solusi selama bertahun-tahun dan menemukan posting ini tentang cara mencetak footer yang berfungsi pada banyak halaman tanpa tumpang tindih konten halaman.

Persyaratan saya adalah IE8, sejauh ini saya telah menemukan bahwa ini tidak berfungsi di Chrome. [ pembaruan ] Mulai 1 Maret 2018, ia juga berfungsi di Chrome

Contoh ini menggunakan tabel dan elemen tfoot dengan mengatur gaya css:

tfoot {display: table-footer-group;}
rweavere
sumber
2
ini bekerja di semua browser dan di asp (yang memiliki beberapa masalah gila dengan footer halaman) Gunakan ini saya katakan.
DWolf
17
@DWolf Komentar pertama beri saya harapan besar. Dan Anda menghancurkan saya dalam satu kalimat setelah itu.
C0ZEN
Saya sebenarnya sudah memiliki pekerjaan ini di Chrome. Saya tidak membuatnya bekerja dalam versi yang sangat lama dari Chromium berbasis linux tetapi Chrome bekerja dengan sangat baik.
njfife
Pada 2019 itu berfungsi di Chrome!
Oleg
13

solusi ajaib benar-benar meletakkan segala sesuatu dalam satu tabel.

  • thead : ini untuk header berulang.

  • tfoot : footer berulang.

  • tbody : isinya.

dan buat satu tr, td dan letakkan semuanya di div

Kode ::

<table class="report-container">
   <thead class="report-header">
     <tr>
        <th class="report-header-cell">
           <div class="header-info">
            ...
           </div>
         </th>
      </tr>
    </thead>
    <tfoot class="report-footer">
      <tr>
         <td class="report-footer-cell">
           <div class="footer-info">
           ...
           </div>
          </td>
      </tr>
    </tfoot>
    <tbody class="report-content">
      <tr>
         <td class="report-content-cell">
            <div class="main">
            ...
            </div>
          </td>
       </tr>
     </tbody>
</table>

table.report-container {
    page-break-after:always;
}
thead.report-header {
    display:table-header-group;
}
tfoot.report-footer {
    display:table-footer-group;
} 

ekstra : untuk mencegah tumpang tindih dengan beberapa halaman. Suka:

<div class="main">
    <div class="article">
        ...
  </div>
    <div class="article">
        ...
  </div>
    <div class="article">
        ...
  </div>
  ...
  ...
  ...
</div>

yang menghasilkan overflow yang akan membuat segalanya tumpang tindih dengan header di dalam page break ..

jadi >> gunakan: page-break-inside: avoid !important;dengan kelas ini article.

table.report-container div.article {
    page-break-inside: avoid;
}

cukup sederhana, harap ini akan memberi Anda hasil terbaik yang Anda inginkan.

salam Hormat. ;)

sumber ..

Biskrem Muhammad
sumber
Solusi terbaik di sini. Beberapa catatan: Flexbox dapat menyebabkan beberapa perilaku yang tidak terduga. Jika Anda ingin footer di halaman LSAT menjadi bagian bawah Anda akan membutuhkan solusi dan solusi dari @Infotekka digabungkan.
Arseniy-II
11

Dari pertanyaan ini - tambahkan gaya berikut ke lembar gaya cetak-saja. Solusi ini akan berfungsi di IE dan Firefox, tetapi tidak di Chrome (pada versi 21):

#header {
  display: table-header-group;
}

#main {
  display: table-row-group;
}

#footer {
  display: table-footer-group;
}
Blazemonger
sumber
1
Saya menemukan solusi ini hanya berfungsi satu. Belum menguji semua browser tetapi berfungsi di Firefox!
Primoz Rome
2
2017 dan masih tidak berfungsi di Chrome! tetapi berfungsi di Firefox
Mehdi Dehghani
@MehdiDehghani: my bad .. melepas komentar
Fr0zenFyr
10

Gunakan istirahat halaman untuk menentukan gaya dalam CSS:

@media all
  {
  #page-one, .footer, .page-break { display:none; }
  }

@media print
  {
  #page-one, .footer, .page-break   
    { 
    display: block;
    color:red; 
    font-family:Arial; 
    font-size: 16px; 
    text-transform: uppercase; 
    }
  .page-break
    {
    page-break-before:always;
    } 
}

Kemudian tambahkan markup di dokumen di tempat yang sesuai:

<h2 id="page-one">unclassified</h2>
<!-- content block -->
<h2 class="footer">unclassified</h2>
<h2 class="page-break">unclassified</h2>
<!-- content block -->
<h2 class="footer">unclassified</h2>
<h2 class="page-break">unclassified</h2>
<!-- content block -->
<h2 class="footer">unclassified</h2>
<h2 class="page-break">unclassified</h2>
<!-- content block -->
<h2 class="footer">unclassified</h2>
<h2 class="page-break">unclassified</h2>

Referensi

Paul Sweatte
sumber
32
Ini tidak mencetak header dan footer pada setiap halaman. Ini menentukan banyak "halaman" dengan tebakan terbaik. Jika Anda tidak tahu tinggi dokumen Anda (jumlah halaman), itu tidak berguna.
rainabba
@rainabbaif the document was printed onto 5 pages
Paul Sweatte
4
itu hanya sebuah contoh. tidak boleh digunakan untuk memandu ans Anda secara tepat .. solusi.
igorsantos07
@ igorsantos07 shouldtidak berarti don't. If(hanya sebuah contoh) kata if(hanya sebuah contoh) digunakan oleh OP, dan if(hanya sebuah contoh) OP tidak lagi aktif, apakah lebih baik memberikan jawaban tertentu if(hanya sebuah contoh) sudah ada jawaban umum dan if(hanya sebuah contoh) bahasa (HTML / CSS) dan spesifikasi yang dimaksud dirancang untuk menghindari tipuan dan menyederhanakan dokumentasi ? If(hanya sebuah contoh) jadi, mengapa? Kalau tidak, mengapa tidak?
Paul Sweatte
5

Saya mencoba untuk melawan pertarungan yang sia-sia ini dengan menggabungkan aturan tfoot & css tetapi hanya berhasil di Firefox :(. Saat menggunakan plain css, konten mengalir di atas footer. Saat menggunakan tfoot, footer di halaman terakhir tidak tetap bagus di bagian bawah. Ini karena footer tabel dimaksudkan untuk tabel, bukan halaman fisik. Diuji pada Chrome 16, Opera 11, Firefox 3 & 6 dan IE6.

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>Header & Footer test</title>

<style>

  @media screen {
    div#footer_wrapper {
      display: none;
    }
  }

  @media print {
    tfoot { visibility: hidden; }

    div#footer_wrapper {
      margin: 0px 2px 0px 7px;
      position: fixed;
      bottom: 0;
    }

    div#footer_content {
      font-weight: bold;
    }
  }

</style>
</head>

<body>

<div id="footer_wrapper">
  <div id="footer_content">
    Total 4923
  </div>
</div>


<TABLE CELLPADDING=6>

<THEAD>
<TR> <TH>Weekday</TH> <TH>Date</TH> <TH>Manager</TH> <TH>Qty</TH> </TR>
</THEAD>

<TBODY>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
<TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kelsey</TD>  <TD>639</TD>  </TR>
<TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Lindsey</TD> <TD>596</TD>  </TR>
<TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Randy</TD>   <TD>1135</TD> </TR>
<TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Susan</TD>   <TD>1002</TD> </TR>
<TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Randy</TD>   <TD>908</TD>  </TR>
<TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Lindsey</TD> <TD>371</TD>  </TR>
<TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Susan</TD>   <TD>272</TD>  </TR>
</TBODY>

<TFOOT id="table_footer">
<TR> <TH ALIGN=LEFT COLSPAN=3>Total</TH> <TH>4923</TH> </TR>
</TFOOT>

</TABLE>

</body>
</html>
jous
sumber
4

Salah satu pendekatan yang hanya berfungsi untuk menambahkan tajuk ke setiap halaman adalah dengan membungkus konten Anda di dalam <table>dan kemudian menempatkan konten tajuk Anda dalam <thead>tag dan konten Anda dalam <tbody>tag, seperti:

<table>
  <thead>
    <tr>
      <th>This content appears on every page</th>
    </tr>
   </thead>
   <tbody>
     <tr>
       <td>Put all your content here, it can span multiple pages and your header will show up at the top of each page</td>
     </tr>
   </tbody>
 </table>

Ini berfungsi di Chrome, tidak 100% yakin tentang browser lain.

Dana Woodman
sumber
1
ini berfungsi selama thead dan tfoot kami tidak memiliki banyak <tr> baris, sepertinya thead dan tfoot memiliki set ketinggian max, dalam kasus saya, saya memiliki 9 <tr> baris dalam thead, ketika saya menguranginya menjadi 3 atau 5 berfungsi
Sundara Prabu
Itu trik yang rapi! Thead bekerja seperti mantra, tetapi tidak bisa. Ada ide tentang cara membuatnya bekerja?
Irikos
Tfoot bekerja di browser, tetapi tidak dalam kata MS. Thead bekerja di keduanya.
Irikos
3

Jika Anda dapat menggunakan javascipt, minta klien menangani meletakkan konten menggunakan javascript untuk menempatkan elemen berdasarkan ruang yang tersedia.

Anda dapat menggunakan plugin jquery columnizer untuk secara dinamis meletakkan konten Anda dalam blok ukuran tetap dan posisikan header dan footer Anda sebagai bagian dari rutin rendering. http://welcome.totheinter.net/columnizer-jquery-plugin/

Lihat contoh 10 http://welcome.totheinter.net/autocolumn/sample10.html

Browser masih akan menambahkan header atau footernya sendiri jika diaktifkan di os. Tata letak yang konsisten di seluruh platform dan browser kemungkinan akan membutuhkan css bersyarat.

sparkalow
sumber
3
Demo yang disediakan bahkan tidak berfungsi (halaman tidak pecah, saling berdarah, dll.), Apalagi dengan konten yang lebih universal.
rainabba
1
Saya harus mengklarifikasi. Tautan yang disediakan adalah contoh perpustakaan javascript untuk meletakkan konten di seluruh wadah dan tidak siap untuk dicetak. Tautan ini dimaksudkan sebagai contoh penggunaan js untuk mengatur konten dalam batas yang ditentukan. Saya telah menggunakan js sebagai mesin rendering dengan wkhtmltopdf untuk membuat buku masak dari konten basis data.
sparkalow
Pertanyaannya adalah tentang mencetak.
Greg Blass
2

Saya terkejut dan tidak terkesan bahwa Chrome memiliki dukungan cetak CSS yang sangat buruk.

Tugas saya diperlukan menampilkan footer yang sedikit berbeda pada setiap halaman. Dalam kasus paling sederhana, hanya bab dan nomor halaman yang bertambah. Dalam kasus yang lebih kompleks, lebih banyak teks dalam footer - misalnya, beberapa catatan kaki - yang dapat memperbesar ukurannya, menyebabkan apa yang ada di area konten halaman menjadi menyusut dan sebagian darinya merefleksikan ke halaman berikutnya.

Cetak CSS tidak dapat menyelesaikan ini, setidaknya tidak dengan dukungan browser yang buruk hari ini. Tetapi melangkah keluar dari cetak, CSS3 dapat melakukan banyak hal:

https://jsfiddle.net/b9chris/moctxd2a/29/

<div class=page>
  <header></header>
  <div class=content>Content</div>
  <footer></footer>
</div>

SCSS:

body {
  @media screen {
    width: 7.5in;
    margin: 0 auto;
  }
}

div.page {
  display: flex;
  height: 10in;    
  flex-flow: column nowrap;
  justify-content: space-between;
  align-content: stretch;
}

div.content {
  flex-grow: 1;
}

@media print {
  @page {
    size: letter;  // US 8.5in x 11in
    margin: .5in;
  }

  footer {
    page-break-after: always;
  }
}

Ada lebih banyak kode dalam contoh, termasuk beberapa Cat Ipsum; tetapi js yang digunakan hanya ada di sana untuk menunjukkan seberapa besar header / footer dapat bervariasi tanpa merusak pagination. Kuncinya adalah mengambil trik kolom-bawah-lengket dari CSS Flexbox dan kemudian menerapkannya ke halaman yang diketahui, ketinggian tetap - dalam hal ini, selembar kertas berukuran US ukuran 8,5 "x11", dengan 0,5. "Margin pergi width: 7.5indan height: 10intepat. Setelah wadah fleksibel CSS diberi tahu ukurannya yang tepat (div.page ), mudah untuk mendapatkan header dan footer untuk memperluas dan mengontrak seperti yang mereka lakukan dalam tipografi konvensional.

Apa yang tersisa mengalir konten halaman ketika footer, misalnya, tumbuh menjadi 8 catatan kaki bukan 3. Dalam kasus saya kontennya cukup diperbaiki sehingga saya tidak perlu khawatir tentang hal itu, tapi saya yakin ada cara untuk melakukannya. Salah satu pendekatan yang melompat ke pikiran, adalah untuk mengubah header dan footer menjadi 100% lebar mengapung, kemudian posisikan dengan Javascript. Peramban akan menangani interupsi aliran konten reguler untuk Anda secara otomatis.

Chris Moschini
sumber
0

Apakah ini sesuatu yang ingin Anda cetak saja? Anda bisa menambahkannya ke setiap halaman di situs Anda dan menggunakan CSS untuk mendefinisikan tag sebagai media hanya-cetak.

Sebagai contoh, ini bisa menjadi contoh tajuk:

<span class="printspan">UNCLASSIFIED</span>

Dan di CSS Anda, lakukan sesuatu seperti ini:

<style type="text/css" media="screen">
    .printspan
    {
        display: none;
    }
</style>
<style type="text/css" media="print">
    .printspan
    {
        display: inline;
        font-family: Arial, sans-serif;
        font-size: 16 pt;
        color: red;
    }
</style>

Akhirnya, untuk memasukkan header / footer pada setiap halaman yang Anda mungkin gunakan termasuk sisi-server atau jika Anda memiliki halaman yang dihasilkan dengan PHP atau ASP, Anda bisa memasukkannya ke file umum.

Edit:

Jawaban ini dimaksudkan untuk memberikan cara untuk menunjukkan sesuatu pada versi cetak fisik dari suatu dokumen sementara tidak menunjukkan sebaliknya. Namun seperti komentar yang disarankan, itu tidak menyelesaikan masalah memiliki catatan kaki di beberapa halaman yang dicetak ketika konten meluap.

Saya meninggalkannya di sini kalau-kalau itu membantu.

JYelton
sumber
4
+1 untuk menggunakan tampilan alih-alih visibilitas - visibilitas: daun tersembunyi menyisakan ruang, sedangkan tampilan: tidak ada yang meruntuhkan ruang putih, menghemat kertas, dan membuat planet Bumi bertahan lebih lama.
Fenton
3
-1: meskipun contoh yang baik dari lembar gaya cetak, itu tidak berurusan dengan masalah ketika konten meluap halaman .. Seperti, ini hanya akan menampilkan catatan kaki di halaman terakhir.
NotMe
0

Jika Anda menggunakan mesin template seperti Asp.net Razor Engine atau Angular, saya pikir Anda harus membuat ulang halaman Anda dan membagi halaman menjadi beberapa halaman dan kemudian Anda dapat dengan bebas menandai setiap halaman dan menempatkan header dan footer pada tema. salah satu contoh bisa seperti di bawah ini:

@page {
  size: A4;  
   margin: .9cm;
}


@media print {

   body.print-paper-a4 {
    width: 210mm;
    height: 297mm;
  }

   body {
       background: white;
       margin: 0;
       padding: 0;
   }

   .print-stage,
   .no-print {
       display: none;
   }


   body.print-paper.a4 .print-paper {
      width: 210mm;
        height: 297mm;
    }

   .print-paper {
       page-break-after: always;
       margin: 0;
       padding: .8cm;
       border:none;
       overflow: hidden;
   }

}





.print-papers {
    display: block;
    z-index: 2000;
    margin: auto;

}


body.print-paper-a4 .print-paper {
    width: 21cm;
    height:27cm;
}


.print-paper {
    margin: auto;
    background: white;
    border: 1px dotted black;
    box-sizing: border-box;
    margin: 1cm auto;
    padding: .8cm;
       overflow: hidden;   
}


body.print-mode .no-print-preview {
    display: none;
}

body.print-mode .print-preview {
    display: block;
}
<body class="print-mode print-paper-a4">
        
        <div class="print-papers print-preview">
            <div class="print-paper">
                <div style="font-size: 5cm">
                    HELLO
                </div>

            </div>
            <div class="print-paper">
              <div class="page-header">
                </div>
              
              
            </div>
            <div class="print-paper">
                
                

            </div>            
        </div>
  </body>

pixparker
sumber
0

Saya menemukan satu solusi. Gagasan dasarnya adalah membuat tabel dan di bagian aad menempatkan data header di tr dan dengan kekuatan css untuk menunjukkan bahwa tr hanya di cetak tidak di layar maka header normal Anda harus dipaksa untuk ditampilkan hanya di layar tidak di cetak. 100% bekerja pada banyak halaman yang dicetak. kode sampel ada di sini

<style> 
    @media screen {
        .only_print{
            display:none;
        }
    }
    @media print {
        .no-print {
            display: none !important;
        }
    }
    TABLE{border-collapse: collapse;}
    TH, TD {border:1px solid grey;}
</style>
<div class="no-print">  <!-- This is header for screen and will not be printed -->
    <div>COMPANY NAME FOR SCREEN</div>
    <div>DESCRIPTION FOR SCREEN</div>
</div>

<table>
    <thead>
        <tr class="only_print"> <!-- This is header for print and will not be shown on screen -->
            <td colspan="100" style="border: 0px;">
                <div>COMPANY NAME FOR PRINT</div>
                <div>DESCRIPTION FOR PRINT</div>
            </td>
        </tr>
        <!-- From here Actual Data of table start -->
        <tr>
            <th>Column 1</th>
            <th>Column 2</th>
            <th>Column 3</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>1-1</td>
            <td>1-2</td>
            <td>1-3</td>
        </tr>
        <tr>
            <td>2-1</td>
            <td>2-2</td>
            <td>2-3</td>
        </tr>
    </tbody>
</table>
AZ Soft
sumber
0

Coba ini, bagi saya ini berfungsi pada Chrome, Firefox dan Safari. Anda akan mendapatkan header dan footer diperbaiki untuk setiap halaman tanpa tumpang tindih konten halaman

CSS

<style>
  @page {
    margin: 10mm;
  }

  body {
    font: 9pt sans-serif;
    line-height: 1.3;

    /* Avoid fixed header and footer to overlap page content */
    margin-top: 100px;
    margin-bottom: 50px;
  }

  #header {
    position: fixed;
    top: 0;
    width: 100%;
    height: 100px;
    /* For testing */
    background: yellow; 
    opacity: 0.5;
  }

  #footer {
    position: fixed;
    bottom: 0;
    width: 100%;
    height: 50px;
    font-size: 6pt;
    color: #777;
    /* For testing */
    background: red; 
    opacity: 0.5;
  }

  /* Print progressive page numbers */
  .page-number:before {
    /* counter-increment: page; */
    content: "Pagina " counter(page);
  }

</style>

HTML

<body>

  <header id="header">Header</header>

  <footer id="footer">footer</footer>

  <div id="content">
    Here your long long content...
    <p style="page-break-inside: avoid;">This text will not be broken between the pages</p>
  </div>

</body>
Fred K
sumber
-2

Berdasarkan beberapa posting, saya pikir position: fixedberfungsi untuk saya.

body {
  background: #eaeaed;
  -webkit-print-color-adjust: exact;
}

.my-footer {
  background: #2db34a;
  bottom: 0;
  left: 0;
  position: fixed;
  right: 0;
}

.my-header {
  background: red;
  top: 0;
  left: 0;
  position: fixed;
  right: 0;
}
<html>

<head>
  <meta charset=utf-8 />
  <title>Header & Footer</title>

</head>

<body>
  <div>
    <div class="my-header">Fixed Header</div>
    <div class="my-footer">Fixed Footer</div>
    <table>
      <thead>
        <tr>
          <th>TH 1</th>
          <th>TH 2</th>
        </tr>
      </thead>
      <tbody>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
        <tr>
          <td>TD 1</td>
          <td>TD 2</td>
        </tr>
      </tbody>
    </table>
  </div>
</body>

</html>

Tekan Ctrl + P di chrome untuk melihat teks header & footer pada setiap halaman. Semoga ini bisa membantu

Justin Patel
sumber
12
Ya, header dan footer dicetak pada setiap halaman tetapi mereka tumpang tindih dengan konten halaman.
Tony