बूटस्ट्रैप - ग्रिड सिस्टम

इस अध्याय में हम बूटस्ट्रैप ग्रिड सिस्टम पर चर्चा करेंगे।

एक ग्रिड क्या है?

जैसा कि wikepedia द्वारा डाला गया है -

ग्राफिक डिजाइन में, एक ग्रिड एक संरचना (आमतौर पर दो-आयामी) है जो सामग्री को संरचना करने के लिए उपयोग की जाने वाली सीधी (ऊर्ध्वाधर, क्षैतिज) रेखाओं की एक श्रृंखला से बनी होती है। यह प्रिंट डिजाइन में लेआउट और सामग्री संरचना को डिजाइन करने के लिए व्यापक रूप से उपयोग किया जाता है। वेब डिज़ाइन में, HTML और CSS का उपयोग करके तेजी से और प्रभावी रूप से एक सुसंगत लेआउट बनाना एक बहुत ही प्रभावी तरीका है।

सरल शब्दों में कहें तो वेब डिज़ाइन ऑर्गनाइज़ और स्ट्रक्चर कंटेंट में ग्रिड, वेबसाइटों को स्कैन करना आसान बनाता है और उपयोगकर्ताओं पर संज्ञानात्मक भार को कम करता है।

बूटस्ट्रैप ग्रिड सिस्टम क्या है?

जैसा कि ग्रिड सिस्टम के लिए बूटस्ट्रैप के आधिकारिक दस्तावेज द्वारा किया गया है -

बूटस्ट्रैप में एक उत्तरदायी, मोबाइल पहला द्रव ग्रिड सिस्टम शामिल है जो उपकरण या व्यूपोर्ट आकार में 12 कॉलम तक उचित रूप से तराजू करता है। इसमें आसान लेआउट विकल्पों के लिए पूर्वनिर्धारित कक्षाएं, साथ ही अधिक अर्थ लेआउट बनाने के लिए शक्तिशाली मिश्रण शामिल हैं।

उपरोक्त कथन को समझते हैं। बूटस्ट्रैप 3 इस मायने में सबसे पहले मोबाइल है कि बूटस्ट्रैप के लिए कोड अब मोबाइल डिवाइस, टैबलेट, और फिर लैपटॉप, डेस्कटॉप जैसे बड़ी स्क्रीन के लिए "एक्सपैंड" घटकों और ग्रिड जैसे छोटे स्क्रीन को लक्षित करके शुरू होता है।

मोबाइल पहली रणनीति

  • Content

    • निर्धारित करें कि सबसे महत्वपूर्ण क्या है।
  • Layout

    • पहले छोटी चौड़ाई के लिए डिजाइन।
    • आधार सीएसएस पता मोबाइल डिवाइस पहले; टैबलेट, डेस्कटॉप के लिए मीडिया क्वेश्चन एड्रेस।
  • Progressive Enhancement

    • स्क्रीन का आकार बढ़ने पर तत्वों को जोड़ें।

बूटस्ट्रैप ग्रिड सिस्टम का कार्य करना

ग्रिड सिस्टम का उपयोग पंक्तियों और स्तंभों की एक श्रृंखला के माध्यम से पृष्ठ लेआउट बनाने के लिए किया जाता है जो आपकी सामग्री को घर देते हैं। यहां बताया गया है कि बूटस्ट्रैप ग्रिड सिस्टम कैसे काम करता है -

  • पंक्तियों को एक के भीतर रखा जाना चाहिए .container उचित संरेखण और पैडिंग के लिए कक्षा।

  • स्तंभों के क्षैतिज समूह बनाने के लिए पंक्तियों का उपयोग करें।

  • सामग्री को कॉलम के भीतर रखा जाना चाहिए, और केवल कॉलम पंक्तियों के तत्काल बच्चे हो सकते हैं।

  • पूर्वनिर्धारित ग्रिड कक्षाएं जैसे .row and .col-xs-4जल्दी से ग्रिड लेआउट बनाने के लिए उपलब्ध हैं। कम मिश्रण का उपयोग अधिक अर्थ लेआउट के लिए भी किया जा सकता है।

  • कॉलम पैडिंग के माध्यम से गटर (स्तंभ सामग्री के बीच अंतराल) बनाते हैं। वह पैडिंग नकारात्मक मार्जिन के माध्यम से पहले और आखिरी कॉलम के लिए पंक्तियों में ऑफसेट है.rows

  • ग्रिड कॉलम आप उपलब्ध बारह बार उपलब्ध कॉलमों की संख्या निर्दिष्ट करके बनाए जाते हैं। उदाहरण के लिए, तीन बराबर स्तंभ तीन का उपयोग करेंगे.col-xs-4

मीडिया के प्रश्नों

मीडिया क्वेरी "सशर्त सीएसएस नियम" के लिए वास्तव में फैंसी शब्द है। यह बस कुछ सीएसएस लागू करता है, जो कुछ शर्तों के आधार पर निर्धारित होता है। यदि उन शर्तों को पूरा किया जाता है, तो स्टाइल लागू किया जाता है।

बूटस्ट्रैप में मीडिया क्वेरी आपको व्यूपोर्ट के आकार के आधार पर सामग्री को स्थानांतरित करने, दिखाने और छिपाने की अनुमति देती है। बूटस्ट्रैप ग्रिड सिस्टम में मुख्य विराम बिंदु बनाने के लिए LESS फाइलों में निम्नलिखित मीडिया प्रश्नों का उपयोग किया जाता है।

/* Extra small devices (phones, less than 768px) */
/* No media query since this is the default in Bootstrap */

/* Small devices (tablets, 768px and up) */
@media (min-width: @screen-sm-min) { ... }

/* Medium devices (desktops, 992px and up) */
@media (min-width: @screen-md-min) { ... }

/* Large devices (large desktops, 1200px and up) */
@media (min-width: @screen-lg-min) { ... }

कभी-कभी ये शामिल करने के लिए विस्तारित होते हैं a max-width सीएसएस को उपकरणों के एक संकीर्ण सेट तक सीमित करने के लिए।

@media (max-width: @screen-xs-max) { ... }
@media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { ... }
@media (min-width: @screen-md-min) and (max-width: @screen-md-max) { ... }
@media (min-width: @screen-lg-min) { ... }

मीडिया क्वेरी में दो भाग होते हैं, एक उपकरण विनिर्देश और फिर एक आकार नियम। उपरोक्त मामले में, निम्नलिखित नियम निर्धारित है -

आइये इस पंक्ति पर विचार करते हैं -

@media (min-width: @screen-sm-min) and (max-width: @screen-sm-max) { ... }

सभी उपकरणों के लिए कोई फर्क नहीं पड़ता कि किस प्रकार की न्यूनतम चौड़ाई के साथ: @ स्क्रीन-एसएम-मिनट यदि स्क्रीन की चौड़ाई @ स्क्रीन-एसएम-मैक्स की तुलना में छोटी हो जाती है , तो कुछ करें

ग्रिड विकल्प

निम्न तालिका के पहलुओं को संक्षेप में बताया गया है कि बूटस्ट्रैप ग्रिड सिस्टम कई उपकरणों पर कैसे काम करता है -

अतिरिक्त छोटे डिवाइस फ़ोन (<768px) छोटे उपकरण टैबलेट (8768px) मध्यम उपकरण डेस्कटॉप (2992px) बड़े उपकरण डेस्कटॉप (Desk1200px)
कठोर व्यवहार हर समय क्षैतिज टूटने के लिए क्षैतिज, ऊपर शुरू करने के लिए ढह गया टूटने के लिए क्षैतिज, ऊपर शुरू करने के लिए ढह गया टूटने के लिए क्षैतिज, ऊपर शुरू करने के लिए ढह गया
अधिकतम कंटेनर चौड़ाई कोई नहीं (ऑटो) 750px 970px 1170px
कक्षा उपसर्ग .col-xs- .col-sm- .col-md- .col-lg-
# कॉलम के 12 12 12 12
अधिकतम स्तंभ चौड़ाई ऑटो 60px 78px 95px
नाले की चौड़ाई

30px

(एक कॉलम के प्रत्येक तरफ 15px)

30px

(एक कॉलम के प्रत्येक तरफ 15px)

30px

(एक कॉलम के प्रत्येक तरफ 15px)

30px

(एक कॉलम के प्रत्येक तरफ 15px)

Nestable हाँ हाँ हाँ हाँ
ऑफसेट हाँ हाँ हाँ हाँ
स्तंभ आदेश हाँ हाँ हाँ हाँ

मूल ग्रिड संरचना

बूटस्ट्रैप ग्रिड की मूल संरचना निम्नलिखित है -

<div class = "container">

   <div class = "row">
      <div class = "col-*-*"></div>
      <div class = "col-*-*"></div>
   </div>
   
   <div class = "row">...</div>
	
</div>

<div class = "container">
   ....
</div>

आइये देखते हैं कुछ सरल ग्रिड उदाहरण -

  • उदाहरण - ढेर-से-क्षैतिज

  • उदाहरण - मध्यम और बड़े उपकरण

  • उदाहरण - मोबाइल, टैबलेट, डेस्कटॉप

उत्तरदायी स्तंभ रीसेट करता है

उपलब्ध ग्रिड के चार स्तरों के साथ, आप उन मुद्दों पर चलने के लिए बाध्य होते हैं जहां कुछ निश्चित बिंदुओं पर, कॉलम एक दूसरे से लम्बे होने के कारण बिल्कुल सही नहीं होते हैं। इसे ठीक करने के लिए, एक वर्ग के संयोजन का उपयोग करें.clearfixऔर निम्न उदाहरण में दिखाए अनुसार उत्तरदायी उपयोगिता वर्ग -

<div class = "container">
   <div class = "row" >
   
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
      </div>
      
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do 
            eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut 
            enim ad minim veniam, quis nostrud exercitation ullamco laboris 
            nisi ut aliquip ex ea commodo consequat.</p>
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do 
            eiusmod tempor incididunt ut.</p>
      </div>

      <div class = "clearfix visible-xs"></div>
      
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Ut enim ad minim veniam, quis nostrud exercitation ullamco 
            laboris nisi ut aliquip ex ea commodo consequat.</p>
      </div>
      
      <div class = "col-xs-6 col-sm-3" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do 
            eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut 
            enim ad minim</p>
      </div>
      
   </div>
</div>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

इस उदाहरण के वांछित परिणाम के लिए अपने व्यूपोर्ट का आकार बदलें या अपने फ़ोन पर देखें।

ऑफ़सेट कॉलम

अधिक विशिष्ट लेआउट के लिए ऑफ़सेट एक उपयोगी विशेषता है। उनका उपयोग अधिक रिक्ति के लिए, (उदाहरण के लिए) स्तंभों को धकेलने के लिए किया जा सकता है। .col-xs = * कक्षाएं ऑफ़सेट का समर्थन नहीं करती हैं, लेकिन उन्हें खाली सेल का उपयोग करके आसानी से दोहराया जाता है।

बड़े डिस्प्ले पर ऑफ़सेट्स का उपयोग करने के लिए, का उपयोग करें .col-md-offset-*कक्षाएं। ये कक्षाएं किसी कॉलम के बाएं हिस्से को बढ़ाती हैं* कॉलम जहां * से रेंज 1 सेवा 11

निम्नलिखित उदाहरण में, हमारे पास <div class = "col-md-6"> .. </ div> है, हम इसे इस वर्ग के साथ केन्द्रित करेंगे। .col-md-offset-3

<div class = "container">

   <h1>Hello, world!</h1>

   <div class = "row" >
      <div class = "col-xs-6 col-md-offset-3" style = "background-color: #dedef8; 
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
      </div>

   </div>
	
</div>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

घोंसले के स्तंभ

डिफ़ॉल्ट ग्रिड के साथ अपनी सामग्री को घोंसले में लाने के लिए, एक नया जोड़ें .row और का सेट .col-md-* एक मौजूदा के भीतर कॉलम .col-md-*स्तंभ। नेस्टेड पंक्तियों में 12 तक जोड़ने वाले स्तंभों का एक सेट शामिल होना चाहिए।

निम्नलिखित उदाहरण में, लेआउट में दो कॉलम हैं, दूसरे के साथ दो पंक्तियों में चार बक्से में विभाजित किया गया है।

<div class = "container">
   <h1>Hello, world!</h1>

   <div class = "row">

      <div class = "col-md-3" style = "background-color: #dedef8; 
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <h4>First Column</h4>
         <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
      </div>

      <div class = "col-md-9" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         <h4>Second Column- Split into 4 boxes</h4>
         <div class = "row">
            
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>Consectetur art party Tonx culpa semiotics. 
                  Pinterest assumenda minim organic quis.</p>
            </div>
            
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>sed do eiusmod tempor incididunt ut labore et dolore magna 
                  aliqua. Ut enim ad minim veniam, quis nostrud exercitation 
                  ullamco laboris nisi ut aliquip ex ea commodo consequat.</p>
            </div>
				
         </div>

         <div class = "row">
			
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>quis nostrud exercitation ullamco laboris nisi ut aliquip 
                  ex ea commodo consequat.</p>
            </div>   
            
            <div class = "col-md-6" style = "background-color: #B18904;
               box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
               
               <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, 
                  sed do eiusmod tempor incididunt ut labore et dolore magna 
                  aliqua. Ut enim ad minim.</p>
            </div>
				
         </div>

      </div>

   </div>
	
</div>

यह निम्नलिखित परिणाम का उत्पादन करेगा -

स्तंभ आदेश

बूटस्ट्रैप ग्रिड सिस्टम की एक और अच्छी विशेषता यह है कि आप कॉलम को एक क्रम में आसानी से लिख सकते हैं, और उन्हें दूसरे में दिखा सकते हैं। आप अंतर्निहित ग्रिड स्तंभों के क्रम को आसानी से बदल सकते हैं.col-md-push-* तथा .col-md-pull-* संशोधक कक्षाएं जहां * से रेंज 1 सेवा 11

निम्नलिखित उदाहरण में हमारे पास दो कॉलम लेआउट हैं जिसमें बाएं कॉलम सबसे संकीर्ण है और साइडबार के रूप में कार्य करता है। हम इन स्तंभों के उपयोग का क्रम स्वैप करेंगे.col-md-push-* तथा .col-md-pull-* कक्षाएं।

<div class = "container">
   <h1>Hello, world!</h1>
   
   <div class = "row">
      <p>Before Ordering</p>
      
      <div class = "col-md-4" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I am on left
      </div>
      
      <div class = "col-md-8" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I am on right
      </div>
      
   </div>
	
   <br>
   
   <div class = "row">
      <p>After Ordering</p>
      
      <div class = "col-md-4 col-md-push-8" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I was on left
      </div>
      
      <div class = "col-md-8 col-md-pull-4" style = "background-color: #dedef8;
         box-shadow: inset 1px -1px 1px #444, inset -1px 1px 1px #444;">
         
         I was on right
      </div>
		
   </div>

</div>

यह निम्नलिखित परिणाम का उत्पादन करेगा -