में चयन नियंत्रण का चयनित विकल्प सेट करना मैंने SO और अन्यत्र पर कई समान मौजूदा उत्तरों का शोध किया है, लेकिन इसका समाधान नहीं मिल रहा है।एक कोणीय 2 मॉडल-संचालित फॉर्म
मैं अपना फॉर्म बनाने के लिए कोणीय 2 में मॉडल संचालित दृष्टिकोण का उपयोग कर रहा हूं, जो कि एक जोड़ और संपादन फ़ॉर्म दोनों है। जब संपादन मोड में, मान किसी सेवा से पुनर्प्राप्त डेटा के साथ आबादी वाले होते हैं: यह पहलू ठीक है क्योंकि सरल पाठ इनपुट सभी सही ढंग से बाध्य होते हैं।
प्रॉपर्टीज़ में से एक 'देश' है और यह एक वस्तु इस प्रकार है:
export class Country {id: number; name: string;}
मैं एक का चयन नियंत्रण जो उपलब्ध देशों की सूची में होगा करने के लिए इस बाध्य करने के लिए चाहते हैं, और से एक जब फॉर्म लोड होता है तो मॉडल पॉप्युलेट होता है। मैं बाध्यकारी का मूल्य देश वस्तु होना चाहता हूं, सिर्फ आईडी नहीं।
यहाँ चुनिंदा नियंत्रण के HTML है:
<select class="form-control" id="country" formControlName="country">
<option value="default">--Select a country--</option>
<option *ngFor="let c of countries" [value]="c">{{c.name}} </option>
</select>
और यहाँ वह जगह है जहाँ मैं घटक वर्ग से मान को करने की कोशिश:
(<FormControl>this.personForm.controls['country'])
.setValue(this.person.country, { onlySelf: true });
लेकिन वहाँ कोई चयनित विकल्प है जब पेज लोड, भले ही कंसोल पुष्टि करता है कि यह.person.country मौजूद है और सही ऑब्जेक्ट के साथ पॉप्युलेट है।
मैं इसे आईडी के साथ काम कर सकता हूं: दृश्य में [value] = "c.id" में बदलना और कक्षा में जोड़ना। और फिर यह काम करता है कि सही विकल्प चुना गया है। समस्या यह है कि चयन अब देश की संपत्ति के लिए एक वस्तु को छोड़ देता है, बस आईडी। मैंने [value] को [ngValue] में बदलने की कोशिश की और एक ही परिणाम प्राप्त किया। मैंने चयनित तत्व में [ngModel] = "देश" भी जोड़ा और इससे कोई मदद नहीं मिली।
मैं किसी भी मदद के लिए आभारी रहूंगा।
कि यह किया! आपकी सहायता के लिए धन्यवाद। फिल्टर के अंत में मुझे कभी भी [0] नहीं मिलती थी - क्या ऐसा है कि मिलान का पहला मान वापस आ गया है? – Matt
हां, यह पहला मूल्य है, सैद्धांतिक रूप से आईडी अद्वितीय है, हालांकि, मुझे उम्मीद है कि केवल एक ही होगा। – silentsod
@silentsod, क्या आप जानते हैं कि कैसे सेट करें और दिखाएं '- एक देश का चयन करें -' डिफ़ॉल्ट मान के रूप में? –