CSS Paged Media - Aturan @ halaman

Media paged berbeda dari media berkelanjutan di mana konten dokumen dipecah menjadi satu atau lebih halaman terpisah. Media berhalaman termasuk kertas, transparansi, halaman yang ditampilkan pada layar komputer, dll.

Standar CSS2 memperkenalkan beberapa fitur kontrol pagination dasar yang memungkinkan penulis membantu browser mencari cara terbaik untuk mencetak dokumen mereka.

Model halaman CSS2 menentukan bagaimana dokumen diformat dalam area persegi panjang - kotak halaman - yang memiliki lebar dan tinggi terbatas. Fitur ini terbagi dalam dua kelompok -

  • Fitur CSS2 yang menentukan tata letak halaman tertentu.
  • Fitur CSS2 yang mengontrol penomoran halaman dokumen.

Menentukan Halaman: aturan @ halaman

CSS2 mendefinisikan "kotak halaman", kotak dengan dimensi terbatas di mana konten dirender. Kotak halaman adalah wilayah persegi panjang yang berisi dua area -

  • The page area- Area halaman mencakup kotak yang diletakkan di halaman itu. Tepi area halaman bertindak sebagai blok awal yang berisi tata letak yang terjadi di antara hentian halaman.

  • The margin area - Ini mengelilingi area halaman.

Anda dapat menentukan dimensi, orientasi, margin, dll., Dari kotak halaman dalam aturan @halaman. Dimensi kotak halaman diatur dengan properti 'ukuran'. Dimensi area halaman adalah dimensi kotak halaman dikurangi area margin.

Misalnya, aturan @ halaman berikut menetapkan ukuran kotak halaman menjadi 8,5 × 11 inci dan membuat margin '2cm' di semua sisi antara tepi kotak halaman dan area halaman -

<style type = "text/css">
   <!--
      @page { size:8.5in 11in; margin: 2cm }
   -->
</style>

Anda dapat menggunakan properti margin, margin-top, margin-bottom, margin-left, dan margin-right dalam aturan @page untuk mengatur margin halaman Anda.

Terakhir, properti marks digunakan di dalam aturan @page untuk membuat potongan dan tanda registrasi di luar kotak halaman pada lembar target. Secara default, tidak ada tanda yang dicetak. Anda dapat menggunakan salah satu atau kedua kata kunci krop dan silang untuk membuat tanda krop dan tanda registrasi, masing-masing, pada halaman cetak target.

Mengatur Ukuran Halaman

The ukuran properti menentukan ukuran dan orientasi dari kotak halaman. Ada empat nilai yang dapat digunakan untuk ukuran halaman -

  • auto - Kotak halaman akan diatur ke ukuran dan orientasi lembar target.

  • landscape- Mengesampingkan orientasi target. Kotak halaman memiliki ukuran yang sama dengan target, dan sisi yang lebih panjang berbentuk horizontal.

  • portrait- Mengesampingkan orientasi target. Ukuran kotak halaman sama dengan target, dan sisi yang lebih pendek horizontal.

  • length- Nilai panjang untuk properti 'size' membuat kotak halaman absolut. Jika hanya satu nilai panjang yang ditentukan, itu mengatur lebar dan tinggi kotak halaman. Nilai persentase tidak diperbolehkan untuk properti 'size'.

Dalam contoh berikut, tepi luar kotak halaman akan sejajar dengan target. Nilai persentase pada properti 'margin' adalah relatif terhadap ukuran target jadi jika dimensi lembar target adalah 21.0cm × 29.7cm (yaitu, A4), marginnya adalah 2.10cm dan 2.97cm.

<style type = "text/css">
   <!--
      @page {
         size: auto;   /* auto is the initial value */
         margin: 10%;
      }
   -->
</style>

Contoh berikut menetapkan lebar kotak halaman menjadi 8,5 inci dan tinggi menjadi 11 inci. Kotak halaman dalam contoh ini memerlukan ukuran lembar target 8,5 "× 11" atau lebih besar.

<style type = "text/css">
   <!--
      @page {
         size: 8.5in 11in;  /* width height */
      }
   -->
</style>

Setelah Anda membuat tata letak halaman bernama, Anda bisa menggunakannya di dokumen Anda dengan menambahkan properti halaman ke gaya yang kemudian diterapkan ke elemen dalam dokumen Anda. Misalnya, gaya ini membuat semua tabel dalam dokumen Anda pada halaman lanskap -

<style type = "text/css">
   <!--
      @page { size : portrait }
      @page rotated { size : landscape }
      table { page : rotated }
   -->
</style>

Karena aturan di atas, saat mencetak, jika browser menemukan elemen <table> dalam dokumen Anda dan tata letak halaman saat ini adalah tata letak potret default, ini memulai halaman baru dan mencetak tabel pada halaman lanskap.

Halaman Kiri, Kanan, dan Pertama

Saat mencetak dokumen dua sisi, kotak halaman di halaman kiri dan kanan harus berbeda. Itu dapat diekspresikan melalui dua pseudo-class CSS sebagai berikut -

<style type = "text/css">
   <!--
      @page :left {
         margin-left: 4cm;
         margin-right: 3cm;
      }

      @page :right {
         margin-left: 3cm;
         margin-right: 4cm;
      }
   -->
</style>

Anda dapat menentukan gaya untuk halaman pertama dokumen dengan: first pseudo-class -

<style type = "text/css">
   <!--
      @page { margin: 2cm } /* All margins set to 2cm */

      @page :first {
         margin-top: 10cm    /* Top margin on first page 10cm */
      }
   -->
</style>

Mengontrol Penomoran Halaman

Kecuali Anda menentukan sebaliknya, Hentian halaman terjadi hanya ketika format halaman berubah atau ketika konten meluap dari kotak halaman saat ini. Untuk memaksa atau menyembunyikan hentian halaman, gunakan properti page-break-before, page-break-after, dan page-break-inside .

Baik page-break-before dan page-break-after menerima kata kunci otomatis, selalu, hindari, kiri, dan kanan .

Kata kunci otomatis adalah default, ini memungkinkan browser menghasilkan jeda halaman sesuai kebutuhan. Kata kunci selalu memaksa jeda halaman sebelum atau sesudah elemen, sementara menghindari menekan jeda halaman tepat sebelum atau setelah elemen. Kata kunci kiri dan kanan memaksa satu atau dua jeda halaman, sehingga elemen dirender di halaman kiri atau kanan.

Menggunakan properti pagination cukup mudah. Misalkan dokumen Anda memiliki header level-1, mulai bab baru dengan header level-2 untuk menunjukkan bagian. Anda ingin setiap bab dimulai di halaman kanan yang baru, tetapi Anda tidak ingin header bagian dipisahkan di hentian halaman dari konten berikutnya. Anda dapat mencapai ini menggunakan aturan berikut -

<style type = "text/css">
   <!--
      h1 { page-break-before : right }
      h2 { page-break-after : avoid }
   -->
</style>

Gunakan hanya auto dan hindari nilai dengan properti page-break-inside . Jika Anda lebih suka tabel Anda tidak dipecah di seluruh halaman jika memungkinkan, Anda akan menulis aturan -

<style type = "text/css">
   <!--
      table { page-break-inside : avoid }
   -->
</style>

Mengontrol Janda dan Anak Yatim

Dalam istilah tipografi, yatim piatu adalah baris paragraf yang terdampar di bagian bawah halaman karena jeda halaman, sedangkan janda adalah baris yang tersisa di bagian atas halaman setelah jeda halaman. Umumnya, halaman yang dicetak tidak terlihat menarik dengan satu baris teks terhampar di bagian atas atau bawah. Kebanyakan printer mencoba meninggalkan setidaknya dua baris teks atau lebih di bagian atas atau bawah setiap halaman.

  • Itu orphans properti menentukan jumlah minimum baris paragraf yang harus ditinggalkan di bagian bawah halaman.

  • Itu widows properti menentukan jumlah minimum baris paragraf yang harus ditinggalkan di bagian atas halaman.

Berikut adalah contoh untuk membuat 4 baris di bagian bawah dan 3 baris di bagian atas setiap halaman -

<style type = "text/css">
   <!--
      @page{orphans:4; widows:2;}
   -->
</style>