के लिए लेआउट कार्यान्वयन मैंने शुरुआत से अच्छी प्रैक्टिस का उपयोग करके स्क्रैच से एक डोजो प्रोजेक्ट शुरू किया। मैं डोजो टूलकिट में वास्तव में नया हूं, इसलिए मैं कई दस्तावेज और नमूने के माध्यम से चल रहा हूं जो मुझे बहुत सी अच्छी चीजें छोड़ते हैं लेकिन भविष्य में देव (या ऐड-ऑन) के लिए आर्किटेक्चर को कार्यान्वित करने के तरीके पर कोई तरीका नहीं है। मैंने वेब की खोज की है और यह dojo boilerplate project पाया है जो इसे सभी को एक साथ रखने के लिए एक अच्छी शुरुआत प्रतीत होता है, लेकिन मुझे कुछ और चाहिए था, मैं एमवीसी पैटर्न को कार्यान्वित करना चाहता था (मुझे जावा देव पर रूवा और रूबी के साथ बहुत अनुभव है) मेरा आवेदन और इस very cool example पर आया। इसलिए, मैंने ऐसा कुछ बनाया जो मेरी परियोजना को व्यवस्थित करने का एक सुंदर कानूनी तरीका प्रतीत होता है। मुझे सही करो, अगर मैं गलत हूं .. या आपके पास बेहतर दृष्टिकोण है।डोजो एमवीसी
अब, मैं शुरू करने के लिए तैयार हूँ। मैंने डोजो टूलकिट वेबसाइट पर कुछ ट्यूटोरियल्स की कोशिश की है। आश्चर्यजनक रूप से भागो जब आपके पास केवल एक पृष्ठ है। लेकिन अभी, मैं सोच रहा था कि मैं अपने 0 आवेदन में इस layout tutorial को कैसे कार्यान्वित करूंगा।
require(["dijit/layout/BorderContainer", "dijit/layout/TabContainer",
"dijit/layout/ContentPane", "dojo/parser"]);
: मैं लेआउट के इस प्रकार चाहते हैं अपने आवेदन के लिए अपने मुख्य लेआउट होने के लिए,
<div
id="appLayout" class="demoLayout"
data-dojo-type="dijit.layout.BorderContainer"
data-dojo-props="design: 'headline'">
<div
class="centerPanel"
data-dojo-type="dijit.layout.ContentPane"
data-dojo-props="region: 'center'">
<div>
<h4>Group 1 Content</h4>
<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. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
</div>
<div>
<h4>Group 2 Content</h4>
</div>
<div>
<h4>Group 3 Content</h4>
</div>
</div>
<div
class="edgePanel"
data-dojo-type="dijit.layout.ContentPane"
data-dojo-props="region: 'top'">Header content (top)</div>
<div
id="leftCol" class="edgePanel"
data-dojo-type="dijit.layout.ContentPane"
data-dojo-props="region: 'left', splitter: true">Sidebar content (left)</div>
</div>
लेकिन यह नहीं मिलता है (हां, तो मैं अपने index.html में कोड के उन टुकड़ों था की कोशिश की)
तो परिणाम मूल रूप से div और मेरा पाठ है, लेकिन कोई भी लेआउट नहीं है। मैं क्या खो रहा हूँ?
मेरा समाधान: मैं अपने सूचकांक (जैसे "कंटेनर") पर केवल एक div बनाउंगा और उसे लोडर (ऐप/run.js) से खिलाऊंगा, (जिसे मुख्य नामक एक और स्क्रिप्ट कहते हैं), यह main.js फ़ाइल एएमडी की अवधारणा का उपयोग कर रहा है (जिसे मैं परिचित होना शुरू कर रहा हूं), और वह मेरे आवेदन के किसी भी उदाहरण के निर्माण को संभालने में कामयाब रहा है। तो, उदाहरण के लिए, मैं मैं भी उपयोग अपने अनुप्रयोगों के लिए dojo boilerplate project मेरी लेआउट और उस फ़ाइल पर यह उदाहरण के लिए एक विशेष दृश्य ...
में स्ट्रिंग प्रतिस्थापन के लिए बहुत साफ! मैंने अभी कुछ ऐसा ही किया है, लेकिन इसके बजाय मैं प्रत्येक कंटेनर के लिए प्रत्येक उदाहरण बना देता हूं (उदा। Applayout.js, sidebar.js, आदि) और बस मेरे main.js के भीतर सब कुछ बनाया। लेकिन मेरा मानना है कि करने का आपका तरीका बेहतर है, क्योंकि मैं कल्पना कर सकता हूं कि बहुत अधिक अलग होने से जटिलता आ सकती है। आपके एचटीएमएल के लिए, मुझे नहीं पता था कि आप वास्तव में ऐसा कर सकते हैं "डोजो/टेक्स्ट !//ui/टेम्पलेट्स/EntryPoint.html" ... बहुत बढ़िया सामान। – fneron
मुझे अभी भी एक प्रश्न है। मैंने जो कुछ किया है, उसे करने की कोशिश की ... और मुझे बी 4 के समान परिणाम मिलते हैं?इसलिए, मूल रूप से, मुझे अभी भी टेम्पलेटस्ट्रिंग मिलती है, लेकिन कोई विजेट नहीं है ... "डीजीआईटी/लेआउट/बॉर्डरकंटनर", "डिजिट/लेआउट/स्टैककॉन्टेनर", "डिजीट/लेआउट/कंटेंटपेन" ठीक से लोड नहीं हो रहा है ! – fneron
मान लीजिए कि आपके 'dojoConfig' को' parseOnLoad: true' पर सेट किया गया है। डिजिटल टेम्पलेट, उदा। _EntryPoint.html_, केवल एक रूट तत्व होना चाहिए अन्यथा विजेट तत्काल विफल हो जाएगा। यह भी संभव है कि आपका 'दिजिट/लेआउट' को पार्स किया गया हो और तुरंत ठीक किया जाए (इसे [फायरबग डोजो एक्सटेंशन] (http://goo.gl/KB5rq) के माध्यम से देखें), लेकिन यह ठीक से स्टाइल नहीं है और इसलिए इसकी ऊंचाई सिर्फ ऊंचाई है इसकी सामग्री (अक्सर 0 पीएक्स)। प्रतिशत में 'डीजिट/लेआउट' डब्ल्यू/ऊंचाई के सभी संलग्न नोड्स को स्पष्ट रूप से परिभाषित किया जाना चाहिए 'ऊंचाई'। मेरे उदाहरण में इसका मतलब है 'एचटीएमएल, बॉडी {ऊंचाई: 100%;}' और टेम्पलेट रूट नोड। – phusick