Cóż ... mam to na elemencie potomnym:
this.event.emit(true);
this.calendarProviderService.addEvent(newEvent).subscribe(
finished => {
if (finished == true) {
console.log (finished);
this.event.emit(false);
}
}
)
Sprawdź, czy emisja „True” działa dobrze. W moim komponencie nadrzędnym mam:
<add-event *ngIf="currentActionArea == "addevent"" (event)="addNewEvent($event)"></add-event>
addNewEvent(event){
console.log("Emit recibido: " + event);
if(event == true){
this.loaderMessage = "Guardando Evento...";
this.loadingEvents = true;
} else {
this.switchButtonModel = "0";
this.currentActionArea = null;
this.getEvents();
}
}
Ale kiedy subskrypcja jest zakończona, wówczas „fałszywa” emisja nie działa.
Możesz mi pomóc?
Odpowiedzi:
1 dla odpowiedzi № 1Problem polegał na tym, że korzystam z usługi, aby ustawić wartość emitera. To nie jest najlepsza praktyka. Rozwiązałem to za pomocą tematu:
import { Subject } from "rxjs/Subject";
@Injectable()
export class CalendarProviderService {
/**
* To emit getActivityWork between two components
*/
private _activityWorkSubject = new Subject<calendarActivityWork>();
public getActivityWork = this._activityWorkSubject.asObservable();
constructor() { }
/**
* To set the activity work value
* @param calendarActivity the activity to show
*/
doActivityWork(calendarActivity : calendarActivityWork){
return this._activityWorkSubject.next(calendarActivity);
}
.
.
.
Mam nadzieję, że to może pomóc każdemu.