पर क्लिक किए जाने तक पता लगाने का पता लगाना नहीं है मेरे पास एक घटक है जिसमें आप कुछ खोज शब्द दर्ज कर सकते हैं और यह * ngFor loop का उपयोग करके सामग्री फ़िल्टर करेगा। समस्या तब होती है जब मैं एक खोज शब्द दर्ज करता हूं, मुझे अद्यतन के लिए दृश्यमान रूप से प्रभाव के लिए स्क्रीन पर क्लिक करने की आवश्यकता होती है।कोणीय 2 -
<li *ngFor="let item of posts | reverse; let i = index; ">
<div class="media" *ngIf="item.doesContainTags(searchTags)">
कोड है कि इनपुट क्षेत्र है जहाँ आप के लिए खोज करने के लिए टैग दर्ज पर निष्पादित होता है:
updateSearchTags() {
event.stopPropagation();
// sorter is what is types into the search by tag input field
this.searchTags = this.sorter.split(',');
}
यहाँ एचटीएमएल कोड का हिस्सा है, जिसमें पाश होता है पोस्ट ऑब्जेक्ट पर स्थिर फ़ंक्शन यहां दिया गया है:
doesContainTags(searchTags: string[]): boolean {
let array = this.tags.split(',');
if(!array || array.length === 0) {return false;}
if(!searchTags || searchTags.length === 0) {return false;}
for(let searchTag of searchTags){
if(array.indexOf(searchTag) === -1) {
} else {
return true;
}
}
return false;
}
यहां कोड है जो पोस्ट प्राप्त करता है उस पर फंस रहे हैं:
subscribeAllPosts(): Observable<Post[]> {
return this.af.database.list('posts')
.map(Post.fromJsonList);
}
तो यह सब काम करता है लेकिन जब तक मैं स्क्रीन पर क्लिक करें परिवर्तन नहीं दिखा रहा है:
this.postsService.subscribeAllPosts()
.do(console.log)
.subscribe(posts => this.posts = posts);
यहाँ postsService में कोड जो नमूदार हो जाता है। इसे अपडेट करने के लिए मैन्युअल रूप से कॉल करने का कोई तरीका है। मैं सोच रहा था कि मैं इसे मैन्युअल रूप से अद्यतन सर्चटैग फ़ंक्शन के भीतर कॉल कर सकता हूं जिसे टैग इनपुट द्वारा खोज में टाइप करने के बाद अपडेट किया गया है लेकिन मुझे यकीन है कि यह कोड क्या करेगा।
- अद्यतन, मैं एक कुंजी दबाने घटना के लिए घटना को बदल दिया है। अब हालांकि मैं इस घटना को दो तरह से बाध्यकारी होने के बाद होने की कोशिश कर रहा हूं क्योंकि यह अब बाध्यकारी होने से पहले ही कर रहा है। अगली बार क्लिक करने के बाद यह प्रत्येक char को दिखाता है।
अद्यतन 2 - कुंजीपटल घटना मिली। जारी क्रमबद्ध
मैंने आपके कोड का प्रयास किया है। ऐसा लगता है कि जब तक मैं टैग खोज फ़ील्ड का ध्यान नहीं छोड़ता तब तक यह अपडेट नहीं होगा। मैंने Update.cearchTags फ़ंक्शन के अंत में यह.cdr.detectChanges() भी कोशिश की है लेकिन कोई अच्छा नहीं है। – Pete
यह मेरे लिए एक समान मुद्दे पर काम करता था जहां एक पर्यवेक्षक हैंडलर में मॉडल मान सेट करना दृश्य में एक क्लिक/UI कार्रवाई तक यूआई अपडेट नहीं कर रहा था। – c0bra