मुझे एक समस्या है जो हाल ही में एक से अधिक मामलों में उगाई गई है, और मैं इसके बारे में जाने का सबसे अच्छा तरीका सोच रहा हूं। इसे बस बताने के लिए:एनजी-दोहराने में AngularJS "हेडर"
मेरे पास एक विशेष आइटम द्वारा क्रमबद्ध एनजी-दोहराने में डेटा प्रदर्शित किया जा रहा है। कहें कि इसे नाम से क्रमबद्ध किया गया है, उदाहरण के लिए। मेरे लक्ष्य वर्णानुक्रमित सूची में पत्र टूट जाता है पर हेडर है:
----A----
Abe Lincoln
Adam Smith
----B----
Barack Obama
Barry Zuckercorn
----C----
...
और इतने पर।
बातें मैं कोशिश की है में शामिल हैं:
- नियंत्रक पूरी तरह से पुनः निर्माण मॉडल का डेटा के रूप में यह आता है के बाद, इसे मैन्युअल रूप से पत्र समूहों की एक सरणी में डाल। उदाहरण के लिए, मेरी सेवा में "पोस्ट" और मेरे नियंत्रक की एक सरणी है, सेवा अद्यतन के रूप में, मैन्युअल रूप से उन "पोस्ट" को "अक्षर समूह" की सरणी में घुमाती है। तो यह संभव है कि दो घोंसला एनजी-दोहराना
हालांकि, यह डेटा के भारी हेरफेर पर निर्भर करता है, और फ्लाई पर डेटा को सॉर्ट करने के लिए यह आसान नहीं है।
- जब मॉडल अद्यतन, नियंत्रक "डोप" मैन्युअल रूप से इसे माध्यम से कदम, जब पत्र में परिवर्तन, और उस तत्व (
post.header = true
) पर एक "शीर्षक" संपत्ति पिगीबैकिंग की जाँच करके डेटा है। फिर ng-repeat यह जांच सकता है कि वर्तमान में जिस तत्व पर है वह शीर्षलेख है, और डीओएम में कुछ और डालने के लिए ng-if का उपयोग करें।
यह थोड़ा क्लीनर महसूस करता है लेकिन एनजी-दोहराने के तरीके के कारण, शीर्षलेख तत्व को एनजी-दोहराने वाले तत्व के समान स्तर पर "शामिल" होना होता है। उदाहरण के लिए, यदि आप <tr>
तत्वों पर एनजी-दोहराने करते हैं, इसका मतलब यह होगा यह, शीर्ष लेख के लिए एक और <tr>
सम्मिलित करने के लिए असंभव हो जाएगा के बाद से विशेष तत्व<tr>
अंदर होने की और अंत में है, साथ उपरोक्त के समान पंक्तियां:
- नियंत्रक "कुंजी अनुक्रमणिका" की एक सूची बनाए रखता है - इसका उपरोक्त दूसरी विधि जैसे डेटा को संशोधित करने का लाभ नहीं है, लेकिन आम तौर पर समान तरीके से काम करता है।
संपादित करें:
मैं एक ब्लॉग पोस्ट here बताया गया हो कि मैं अंत में इस मुद्दे को संभाला लिखा है - Google समूह चर्चा नीचे इयान के जवाब से जुड़े करने के लिए धन्यवाद।
इसके लिए धन्यवाद। मैं आसानी से अपनी स्थिति को अनुकूलित कर सकता हूं – cemulate