Я новичок в angular. Я пытался отправить некоторые формоданные из одного компонента в другой с помощью службы, но он сталкивается с некоторой проблемой, т. Е. Он отображает сообщение об ошибке как
ошибка TS2339: свойство 'подписаться«не существует по типу» (data: any) => void '.
Это компонент, который у меня был, мои данные
import { Component, OnInit } from '@angular/core';
import { JarwisService } from '../../Services/jarwis.service';
import { DataTransferService } from '../../dt-broker/dt-core/services/data-transfer.service';
import { Router } from '@angular/router';
import { HttpClient, HttpHeaders } from '@angular/common/http';
import { ActivatedRoute } from '@angular/router';
import { environment } from 'environments/environment';
import { NgForm } from '@angular/forms';
declare var $: any;
@Component({
selector: 'app-addlist',
templateUrl: './addlist.component.html',
styleUrls: ['./addlist.component.css']
})
export class AddlistComponent implements OnInit {
constructor(private Jarwis:JarwisService,
private dataTrans: DataTransferService,
private router : Router,
private http: HttpClient,
private _router : Router,
private activatedRoute: ActivatedRoute) { }
preview(form: NgForm){
this.Jarwis.getpreviewcontent(form.value).subscribe(
viewdata => this.handlepreviewResponse(viewdata)
);
}
handlepreviewResponse(data){
this.dataTrans.setpreviewdata(data);
this.router.navigate(['/previewad']);
}
}
Это компонент, который яхочу отправить данные
import { Component, OnInit } from '@angular/core';
import { DataTransferService } from '../../../dt-broker/dt-core/services/data-transfer.service';
@Component({
selector: 'ngx-previewad',
templateUrl: './previewad.component.html',
styleUrls: ['./previewad.component.scss']
})
export class PreviewadComponent implements OnInit {
constructor(private dataTrans: DataTransferService) { }
public result=null;
ngOnInit() {
// console.log(this.dataTrans.setpreviewdata);
//alert(this.result);
this.dataTrans.setpreviewdata.subscribe(message => this.result = message);
}
}
Это служба, которую я написал для передачи данных
import { Injectable } from '@angular/core';
import { BehaviorSubject } from 'rxjs';
@Injectable({
providedIn: 'root'
})
export class DataTransferService {
private previewdata = new BehaviorSubject('no data');
datapreview = this.previewdata.asObservable();
constructor() { }
setpreviewdata(data){
return this.previewdata.next(data);
//console.log(this.datapreview);
}
}
Любая помощь является заметной.