सीएसएस पृष्ठांकित मीडिया - @ पृष्ठ नियम
पृष्ठांकित मीडिया निरंतर मीडिया से भिन्न होता है जिसमें दस्तावेज़ की सामग्री एक या अधिक असतत पृष्ठों में विभाजित होती है। पृष्ठांकित मीडिया में कागज, पारदर्शिता, कंप्यूटर स्क्रीन पर प्रदर्शित होने वाले पृष्ठ आदि शामिल हैं।
CSS2 मानक कुछ बुनियादी पृष्ठ पर नियंत्रण सुविधाओं को प्रस्तुत करता है जो लेखकों को यह पता लगाने में मदद करते हैं कि उनके दस्तावेज़ों को कैसे प्रिंट किया जाए।
CSS2 पेज मॉडल निर्दिष्ट करता है कि एक आयताकार क्षेत्र के भीतर एक दस्तावेज़ कैसे स्वरूपित किया गया है - पृष्ठ बॉक्स - जिसमें एक परिमित चौड़ाई और ऊंचाई है। ये सुविधाएँ दो समूहों में आती हैं -
- CSS2 की विशेषताएं जो एक विशेष पृष्ठ लेआउट को परिभाषित करती हैं।
- CSS2 की विशेषताएँ जो किसी दस्तावेज़ के पृष्ठांकन को नियंत्रित करती हैं।
परिभाषित पृष्ठ: @ पृष्ठ नियम
CSS2 एक "पेज बॉक्स" को परिभाषित करता है, परिमित आयामों का एक बॉक्स जिसमें सामग्री प्रदान की जाती है। पृष्ठ बॉक्स एक आयताकार क्षेत्र है जिसमें दो क्षेत्र शामिल हैं -
The page area- पेज क्षेत्र में उस पेज पर रखे गए बॉक्स शामिल होते हैं। पृष्ठ क्षेत्र के किनारे पृष्ठ विराम के बीच होने वाले लेआउट के लिए प्रारंभिक युक्त ब्लॉक के रूप में कार्य करते हैं।
The margin area - यह पृष्ठ क्षेत्र को घेरता है।
आप किसी @ पृष्ठ नियम के भीतर पृष्ठ बॉक्स के आयाम, अभिविन्यास, मार्जिन आदि को निर्दिष्ट कर सकते हैं। पृष्ठ बॉक्स के आयाम 'आकार' संपत्ति के साथ सेट किए गए हैं। पृष्ठ क्षेत्र के आयाम पृष्ठ बॉक्स के आयाम हैं मार्जिन क्षेत्र।
उदाहरण के लिए, निम्न @पृष्ठ नियम पृष्ठ बॉक्स का आकार 8.5 × 11 इंच निर्धारित करता है और पेज बॉक्स किनारे और पृष्ठ क्षेत्र के बीच सभी तरफ '2cm' मार्जिन बनाता है -
<style type = "text/css">
<!--
@page { size:8.5in 11in; margin: 2cm }
-->
</style>
आप अपने पेज के लिए मार्जिन सेट करने के लिए मार्जिन, मार्जिन-टॉप, मार्जिन-बॉटम, मार्जिन-लेफ्ट और मार्जिन-राइट प्रॉपर्टीज का इस्तेमाल कर सकते हैं।
अंत में, टार्गेट शीट पर पेज बॉक्स के बाहर फसल और पंजीकरण के निशान बनाने के लिए @ प्रॉपर्टी नियम के भीतर अंक संपत्ति का उपयोग किया जाता है। डिफ़ॉल्ट रूप से, कोई निशान मुद्रित नहीं होते हैं। आप लक्ष्य प्रिंट पृष्ठ पर क्रमशः, फसल अंक और पंजीकरण अंक बनाने के लिए एक या दोनों फसल और क्रॉस कीवर्ड का उपयोग कर सकते हैं ।
पेज साइज़ सेट करना
आकार संपत्ति आकार और एक पेज बॉक्स के उन्मुखीकरण निर्दिष्ट करता है। चार मान हैं जो पृष्ठ आकार के लिए उपयोग किए जा सकते हैं -
auto - पेज बॉक्स को लक्ष्य शीट के आकार और अभिविन्यास पर सेट किया जाएगा।
landscape- लक्ष्य के उन्मुखीकरण को ओवरराइड करता है। पृष्ठ बॉक्स लक्ष्य के समान आकार है, और लंबे पक्ष क्षैतिज हैं।
portrait- लक्ष्य के उन्मुखीकरण को ओवरराइड करता है। पृष्ठ बॉक्स लक्ष्य के समान आकार है, और छोटे पक्ष क्षैतिज हैं।
length- 'आकार' संपत्ति के लिए लंबाई मान एक पूर्ण पृष्ठ बॉक्स बनाते हैं। यदि केवल एक लंबाई मान निर्दिष्ट किया जाता है, तो यह पेज बॉक्स की चौड़ाई और ऊंचाई दोनों निर्धारित करता है। प्रतिशत मानों को 'आकार' संपत्ति के लिए अनुमति नहीं है।
निम्नलिखित उदाहरण में, पृष्ठ बॉक्स के बाहरी किनारों को लक्ष्य के साथ संरेखित किया जाएगा। 'मार्जिन' संपत्ति पर प्रतिशत मूल्य लक्ष्य आकार के सापेक्ष है, इसलिए यदि लक्ष्य शीट आयाम 21.0 सेमी × 29.7 सेमी (अर्थात, ए 4) हैं, तो मार्जिन 2.10 सेमी और 2.97 सेमी हैं।
<style type = "text/css">
<!--
@page {
size: auto; /* auto is the initial value */
margin: 10%;
}
-->
</style>
निम्न उदाहरण पृष्ठ बॉक्स की चौड़ाई 8.5 इंच और ऊंचाई 11 इंच होना तय करता है। इस उदाहरण में पेज बॉक्स को 8.5 "× 11" या उससे बड़े लक्ष्य शीट आकार की आवश्यकता होती है।
<style type = "text/css">
<!--
@page {
size: 8.5in 11in; /* width height */
}
-->
</style>
एक बार जब आप एक नामित पृष्ठ लेआउट बनाते हैं, तो आप इसे अपने दस्तावेज़ में उस पृष्ठ की संपत्ति को एक शैली में जोड़कर उपयोग कर सकते हैं जो बाद में आपके दस्तावेज़ में एक तत्व पर लागू होती है। उदाहरण के लिए, यह शैली लैंडस्केप पृष्ठों पर आपके दस्तावेज़ की सभी तालिकाओं को प्रस्तुत करती है -
<style type = "text/css">
<!--
@page { size : portrait }
@page rotated { size : landscape }
table { page : rotated }
-->
</style>
उपर्युक्त नियम के कारण, मुद्रण करते समय, यदि ब्राउज़र आपके दस्तावेज़ में एक <तालिका> तत्व का सामना करता है और वर्तमान पृष्ठ लेआउट डिफ़ॉल्ट पोर्ट्रेट लेआउट है, तो यह एक नया पृष्ठ शुरू करता है और परिदृश्य पृष्ठ पर तालिका प्रिंट करता है।
बाएँ, दाएँ, और पहले पृष्ठ
डबल-पक्षीय दस्तावेजों को प्रिंट करते समय, बाएं और दाएं पृष्ठों पर पृष्ठ बक्से अलग-अलग होने चाहिए। इसे दो सीएसएस छद्म वर्गों के माध्यम से व्यक्त किया जा सकता है -
<style type = "text/css">
<!--
@page :left {
margin-left: 4cm;
margin-right: 3cm;
}
@page :right {
margin-left: 3cm;
margin-right: 4cm;
}
-->
</style>
आप दस्तावेज़ के पहले पृष्ठ के लिए शैली निर्दिष्ट कर सकते हैं: पहला छद्म वर्ग -
<style type = "text/css">
<!--
@page { margin: 2cm } /* All margins set to 2cm */
@page :first {
margin-top: 10cm /* Top margin on first page 10cm */
}
-->
</style>
पेजिनेशन को नियंत्रित करना
जब तक आप अन्यथा निर्दिष्ट नहीं करते हैं, तब पृष्ठ विराम केवल तब होता है जब पृष्ठ प्रारूप बदलता है या जब सामग्री वर्तमान पृष्ठ बॉक्स को ओवरफ्लो करती है। अन्यथा पेज को तोड़ने या दबाने के लिए, पृष्ठ-विराम से पहले, पृष्ठ-विराम के बाद, और पृष्ठ-विराम के अंदर गुणों का उपयोग करें।
दोनों पेज ब्रेक-से पहले और पेज-अलग होने के बाद स्वीकार ऑटो, हमेशा की तरह, से बचने, बाएँ, और सही खोजशब्दों।
कीवर्ड ऑटो डिफ़ॉल्ट है, यह ब्राउज़र को आवश्यकतानुसार पेज ब्रेक उत्पन्न करता है। तत्व के पहले या बाद में कीवर्ड हमेशा पृष्ठ विराम को बाध्य करता है, जबकि तत्व से पहले या बाद में पृष्ठ विराम को दबाने से बचना चाहिए । छोड़ दिया और सही कीवर्ड्स, एक या दो पृष्ठ विराम मजबूर ताकि तत्व एक बाएं हाथ या दाएँ हाथ के पृष्ठ पर प्रदान की गई है।
पेजिनेशन गुण का उपयोग करना काफी सीधा है। मान लीजिए कि आपके दस्तावेज़ में लेवल -1 हेडर हैं, खंडों को दर्शाने के लिए लेवल -2 हेडर के साथ नए अध्याय शुरू करते हैं। आप प्रत्येक अध्याय को एक नए, दाएं हाथ के पृष्ठ पर शुरू करना चाहते हैं, लेकिन आप नहीं चाहते हैं कि अनुभाग हेडर बाद की सामग्री से पृष्ठ विराम में विभाजित हो। आप निम्नलिखित नियम का उपयोग करके इसे प्राप्त कर सकते हैं -
<style type = "text/css">
<!--
h1 { page-break-before : right }
h2 { page-break-after : avoid }
-->
</style>
केवल ऑटो का उपयोग करें और पेज-ब्रेक-इन संपत्ति के साथ मूल्यों से बचें । यदि आप पसंद करते हैं कि यदि संभव हो तो आपकी टेबल को पृष्ठों पर नहीं तोड़ा जाए, तो आप नियम लिखेंगे
<style type = "text/css">
<!--
table { page-break-inside : avoid }
-->
</style>
विधवाओं और अनाथों को नियंत्रित करना
टाइपोग्राफिक लिंगो में, अनाथ एक पृष्ठ विराम के कारण पृष्ठ के निचले भाग में फंसे हुए पैराग्राफ की वे पंक्तियाँ होती हैं, जबकि विधवाएँ पृष्ठ विच्छेद के बाद किसी पृष्ठ के शीर्ष पर स्थित वे पंक्तियाँ होती हैं। आम तौर पर, मुद्रित पृष्ठ शीर्ष या तल पर फंसे पाठ की एकल पंक्तियों के साथ आकर्षक नहीं लगते हैं। अधिकांश प्रिंटर प्रत्येक पृष्ठ के ऊपर या नीचे पाठ की कम से कम दो या अधिक पंक्तियों को छोड़ने का प्रयास करते हैं।
orphans प्रॉपर्टी एक पैराग्राफ की लाइनों की न्यूनतम संख्या को निर्दिष्ट करती है जिसे एक पृष्ठ के नीचे छोड़ दिया जाना चाहिए।
widows प्रॉपर्टी एक पैराग्राफ की लाइनों की न्यूनतम संख्या को निर्दिष्ट करती है जिसे एक पृष्ठ के शीर्ष पर छोड़ दिया जाना चाहिए।
यहां नीचे की तरफ 4 लाइनें और प्रत्येक पृष्ठ के शीर्ष पर 3 लाइनें बनाने का उदाहरण दिया गया है -
<style type = "text/css">
<!--
@page{orphans:4; widows:2;}
-->
</style>