नेटिवस्क्रिप्ट - लेआउट कंटेनर

NativeScript यूआई विजेट घटक बिछाने के एकमात्र उद्देश्य के लिए कंटेनर घटक का संग्रह प्रदान करता है। लेआउट कंटेनर मूल घटक के रूप में कार्य करते हैं और इसमें एक या अधिक बाल घटक हो सकते हैं। एक लेआउट कंटेनर के सभी बाल घटकों को उसके मूल लेआउट कंटेनर द्वारा प्रदान की गई तकनीक के आधार पर व्यवस्थित किया जा सकता है।

नेटिवस्क्रिप्ट छह लेआउट कंटेनरों का समर्थन करता है और वे इस प्रकार हैं -

  • निरपेक्ष लेआउट कंटेनर

  • डॉक लेआउट कंटेनर

  • ग्रिड लेआउट कंटेनर

  • स्टैक लेआउट कंटेनर

  • लपेटें कंटेनर

  • FlexBox लेआउट कंटेनर

आइए इस अध्याय में सभी लेआउट कंटेनर अवधारणाओं के बारे में विस्तार से जानें।

पूर्ण लेआउट

AbsoluteLayoutकंटेनर नेटिवस्क्रिप्ट में सबसे सरल लेआउट कंटेनर है। AbsoluteLayout अपने बच्चों पर किसी भी बाधा को लागू नहीं करता है और मूल के रूप में शीर्ष-बाएं कोने के साथ 2-आयामी समन्वय प्रणाली का उपयोग करके अपने बच्चों को इसके अंदर रखेगा।

AbsoluteLayout अपने बच्चों के चार गुणों का उपयोग करके उन्हें स्थिति देता है और वे इस प्रकार हैं -

top - बच्चे की उत्पत्ति को y दिशा में नीचे की ओर बढ़ने से निर्धारित करता है।

left - x दिशा में मूल चलती फुटपाथ से बच्चे के स्थान को परिभाषित करता है।

width - बच्चे की चौड़ाई को परिभाषित करता है।

height - बच्चे की ऊंचाई को परिभाषित करता है।

हमें नीचे दिए गए आवेदन के मुख पृष्ठ में AbsoluteLayout कंटेनर जोड़ें -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 

<AbsoluteLayout width="200" height="300" backgroundColor="blue"> 
   <Label text="Top Left" left="0" top="0" width="100" height="150" backgroundColor="green">
   </Label> 
   <Label text="Top Right" left="100" top="0" width="100" height="150" backgroundColor="blue"></Label> 
   <Label text="Bottom Left" left="0" top="150" width="100" height="150" backgroundColor="orange">
   </Label>
   <Label text="Bottom Right" left="100" top="150" width="100" height="150" backgroundColor="red"></Label> 
</AbsoluteLayout>

उत्पादन

AbsoluteLayout का आउटपुट निम्नानुसार है -

DockLayout

Docklayoutकंटेनर घटक अपने बच्चों को इसके अंदर गोदी करने में सक्षम बनाता है। कंटेनर के प्रत्येक तरफ (ऊपर, नीचे, बाएं, दाएं) एक बच्चे के घटक को डॉक कर सकते हैं। DockLayout कंटेनर अपने बच्चों की डॉक प्रॉपर्टी का उपयोग उन्हें सही तरीके से डॉक करने के लिए करता है।

डॉक प्रॉपर्टी के संभावित मूल्य इस प्रकार हैं -

top - लेआउट कंटेनर शीर्ष कोने पर बच्चे के घटक डॉक।

bottom - लेआउट कंटेनर नीचे कोने में बच्चे के घटक को गोदी में लेते हैं।

left - लेआउट कंटेनर में बाएं कोने पर बच्चे के घटक को डॉक करें।

right - लेआउट कंटेनर दाएं कोने पर बच्चे के घटक को डॉक करते हैं।

डिफ़ॉल्ट रूप से, DockLayoutकंटेनर अपने अंतिम बाल घटक को डॉक करता है। यह अपनी stretchLastChild संपत्ति को शून्य पर सेट करके ओवरराइड कर सकता है।

हमें जोड़ते हैं DockLayout नीचे दिए गए हमारे आवेदन के मुख पृष्ठ में कंटेनर -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<DockLayout width="250" height="300" backgroundColor="blue" stretchLastChild="false"> 
   <Label text="left" dock="left" width="50" backgroundColor="green"></Label> 
   <Label text="top" dock="top" height="50" backgroundColor="orange"></Label> 
   <Label text="right" dock="right" width="50" backgroundColor="red"></Label< 
   <Label text="bottom" dock="bottom" height="50" 
   backgroundColor="orange"></Label> 
</DockLayout>

उत्पादन

नीचे DockLayout के लिए आउटपुट है -

जाली का नक्शा

ग्रिडलेयआउट कंटेनर घटक जटिल लेआउट कंटेनर में से एक है और पंक्तियों और स्तंभों के साथ सारणीबद्ध प्रारूप में बाल तत्वों की व्यवस्था करता है। डिफ़ॉल्ट रूप से, इसमें एक पंक्ति और एक कॉलम होता है। इसके निम्नलिखित गुण हैं -

columns- द्वारा अलग किए गए प्रत्येक कॉलम की डिफ़ॉल्ट चौड़ाई का प्रतिनिधित्व करने के लिए उपयोग किया जाता है। संभावित मान संख्या, * और ऑटो कीवर्ड हैं।

कहाँ पे,

  • संख्या एक पूर्ण स्तंभ चौड़ाई को इंगित करती है।

  • अन्य स्तंभों के सापेक्ष स्तंभ की चौड़ाई इंगित करता है। यह इंगित करने के लिए कि स्तंभ की चौड़ाई अन्य स्तंभ के सापेक्ष कितनी बार होनी चाहिए, यह संख्या से पहले हो सकती है। उदाहरण के लिए, 2 * इंगित करें कि चौड़ाई स्तंभ के सबसे छोटे स्तंभ की चौड़ाई से 2 गुना होनी चाहिए।

  • ऑटो कॉलम की चौड़ाई को उसके सबसे चौड़े बच्चे की तरह इंगित करता है।

उदाहरण के लिए, *, 2 * का अर्थ है दो कॉलम और दूसरा पहले कॉलम के आकार का दोगुना होगा।

rows - प्रत्येक पंक्ति की डिफ़ॉल्ट ऊंचाई का प्रतिनिधित्व करने के लिए, द्वारा अलग किया जाता है। मान प्रतिनिधित्व कॉलम के समान है।

GridLayout अपने बच्चों के नीचे निर्दिष्ट गुणों का उपयोग उन्हें लेआउट करने के लिए करता है -

row - पंक्ति संख्या

col - कॉलम संख्या

rowSpan - कुल पंक्तियों की संख्या जो बाल सामग्री एक लेआउट के भीतर फैली हुई है।

colSpan - बच्चे की सामग्री की कुल संख्या एक लेआउट के भीतर फैली हुई है।

हमें नीचे दिए गए हमारे आवेदन के मुख पृष्ठ में ग्रिडलाइउट कंटेनर जोड़ें -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<GridLayout columns="50, auto, *" rows="50, auto, *" width="210" height="210"
   backgroundColor="blue"> 
   <Label text="Row: 0; Column 0" row="0" col="0" backgroundColor="green"></Label> 
   <Label text="Row: 0; Column 1" row="0" col="1" colSpan="1" backgroundColor="brown"></Label> 
   <Label text="Row: 1; Column 0" row="1" col="0" rowSpan="1" backgroundColor="red"></Label> 
   <Label text="Row: 1; Column 1" row="1" col="1" backgroundColor="orange"></Label> 
</GridLayout>

उत्पादन

नीचे ग्रिडलाइउट का आउटपुट दिया गया है -

StackLayout

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

हमें नीचे दिए गए आवेदन के मुख पृष्ठ में StackLayout कंटेनर जोड़ें -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<StackLayout orientation="vertical" width="200" height="200" backgroundColor="blue"> 
   <Label text="Label1" width="50" height="50" backgroundColor="green"></Label> 
   <Label text="Label2" width="50" height="50" backgroundColor="brown"></Label> 
   <Label text="Label3" width="50" height="50" backgroundColor="red"></Label> 
   <Label text="Label4" width="50" height="50" backgroundColor="orange"></Label> 
</StackLayout>

उत्पादन

StackLayout के लिए आउटपुट नीचे दिखाया गया है -

WrapLayout

WrapLayout का उपयोग नई पंक्तियों या स्तंभों पर सामग्री लपेटने के लिए किया जाता है।

इसके निम्नलिखित तीन गुण हैं -

orientation - क्षैतिज या लंबवत रूप से प्रदर्शित करें।

itemWidth - प्रत्येक बच्चे के लिए लेआउट चौड़ाई।

itemHeight - प्रत्येक बच्चे के लिए लेआउट ऊंचाई।

नीचे दिए गए हमारे आवेदन के मुख पृष्ठ में WrapLayout कंटेनर जोड़ें -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> <WrapLayout orientation="horizontal" width="200" height="200" backgroundColor="blue">
   <Label text="Label1" width="70" height="70" backgroundColor="green"></Label> 
   <Label text="Label2" width="70" height="70" backgroundColor="brown"></Label 
   <Label text="Label3" width="70" height="70" backgroundColor="red"></Label> 
   <Label text="Label4" width="70" height="70" backgroundColor="orange"></Label> 
</WrapLayout>

उत्पादन

फ्लेक्सबॉक्स लेआउट

FlexboxLayout कंटेनर घटक उन्नत लेआउट कंटेनर में से एक है। यह बहुत जटिल और परिष्कृत लेआउट के लिए सरल लेआउट प्रदान करने का विकल्प प्रदान करता है। यह CSS फ्लेक्सबॉक्स पर आधारित है।

FlexboxLayout घटक में बहुत सारे गुण हैं और वे इस प्रकार हैं -

flexDirection

यह उस दिशा का प्रतिनिधित्व करता है जिसमें बच्चे के घटक व्यवस्थित होते हैं। FlexDirection के संभावित मान इस प्रकार हैं -

row - बाल घटकों को कंधे से कंधा मिलाकर व्यवस्थित किया जाता है।

row-reverse - बाल घटकों को कंधे से कंधा मिलाकर उल्टा दिशा में व्यवस्थित किया जाता है।

column - बाल घटकों को एक दूसरे के नीचे व्यवस्थित किया जाता है।

column-reverse - बाल घटकों को एक के नीचे एक, लेकिन उल्टी दिशा में व्यवस्थित किया जाता है।

आइए हम अपने आवेदन के मुख पृष्ठ में FlexLayout कंटेनर को नीचे के रूप में जोड़ते हैं -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<FlexboxLayout flexDirection="row"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

उत्पादन

नीचे FlexLayout का उत्पादन है - पंक्ति -

अब, हम flexDirection मान को पंक्ति से पंक्ति-रिवर्स में बदलते हैं और जाँचते हैं कि यह लेआउट को कैसे प्रभावित करता है।

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> <FlexboxLayout flexDirection="row-reverse"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

उत्पादन

नीचे फ्लेक्स लेआउट का उत्पादन है - पंक्ति रिवर्स -

आइए हम रो-रिवर्स से कॉलम में फ्लेक्सडायरेक्शन मूल्य को बदलते हैं और यह जांचते हैं कि यह लेआउट को कैसे प्रभावित करता है।

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<FlexboxLayout flexDirection="column"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

उत्पादन

FlexLayout के लिए आउटपुट - कॉलम नीचे दिया गया है -

आइए हम फ्लेक्सडायरेक्शन मूल्य को कॉलम से कॉलम-रिवर्स में बदलें और जांचें कि यह लेआउट को कैसे प्रभावित करता है।

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<FlexboxLayout flexDirection="column-reverse"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

उत्पादन

नीचे FlexLayout का आउटपुट है - कॉलम रिवर्स -

flexWrap

यह दर्शाता है कि फ्लेक्सडायरेक्शन द्वारा निर्धारित दिशा में लपेटकर बाल घटकों को एक पंक्ति / स्तंभ में प्रस्तुत किया जाएगा या कई पंक्तियों में प्रवाहित किया जाएगा।

संभावित मान इस प्रकार हैं -

wrap - दिए गए दिशा (flexDirection) में कोई स्थान उपलब्ध नहीं होने पर, बच्चों के घटकों को लपेटता है।

wrap-reverse - विपरीत दिशा में घटक प्रवाह को छोड़कर रैप के समान।

हमें flexWrap गुण जोड़ते हैं और फिर रैप के रूप में इसका मान सेट करते हैं। नीचे बताए अनुसार तीन और बच्चे भी जोड़ें -

<ActionBar> 
   <Label text="Home"></Label> 
&tl;/ActionBar> 
<FlexboxLayout flexDirection="row" flexWrap="wrap"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label>
   <Label text="Sixth Item" backgroundColor="green"></Label> 
   <Label text="Seventh Item" backgroundColor="red"></Label> 
   <Label text="Eighth Item" backgroundColor="green"></Label> 
</FlexboxLayout>

उत्पादन

नीचे flexWrap के लिए उत्पादन है -

JustifyContent

यह दर्शाता है कि एक दूसरे और समग्र संरचना के संबंध में बाल घटकों की व्यवस्था कैसे की जाती है। नीचे दिए गए अनुसार इसके तीन गुण हैं -

flex-end - यह चाइल्ड कंपोनेंट को अंतिम लाइन की ओर पैक करता है।

space-between - यह लाइन में समान रूप से वितरित करके बच्चे के घटक को पैक करता है।

space-around - स्पेस-बीच के समान यह सिवाय इसके कि चाइल्ड कंपोनेंट को समान रूप से लाइन में बांटने के साथ-साथ उनके आसपास के बराबर स्पेस पैक करता है।

आइए हम औचित्यपूर्ण जोड़ें और यह जांचें कि यह कैसे व्यवहार करता है -

<ActionBar> 
   <Label text="Home"></Label>
</ActionBar> 
<FlexboxLayout flexDirection="row" flexWrap="wrap" justifyContent="space-around"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
   <Label text="Sixth Item" backgroundColor="green"></Label> 
   <Label text="Seventh Item" backgroundColor="red"></Label> 
   <Label text="Eighth Item" backgroundColor="green"></Label> 
</FlexboxLayout>

उत्पादन

नीचे फ्लेक्स लेआउट का उत्पादन है - औचित्य -

FlexLayout कंटेनर अपने बच्चों को आदेश और सिकुड़ने की क्षमता को निर्दिष्ट करने के लिए दो और गुण प्रदान करता है। वे इस प्रकार हैं -

order - यह उस आदेश को निर्धारित करता है जिसमें FlexLayout कंटेनर के बच्चों को प्रदान किया जाएगा।

flexShrink - यह बच्चों के स्तर 0 तक सिकुड़ने की क्षमता को निर्धारित करता है।