【发布时间】:2019-03-30 03:55:45
【问题描述】:
我是 Angular 的新手,我尝试使用服务将一些表单数据从一个组件发送到另一个组件,但它面临一些问题,即它显示错误消息为
错误 TS2339:类型“(数据:任意)=> 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);
}
}
任何帮助都是可观的。
【问题讨论】:
-
this.dataTrans.setpreviewdata.subscribe(message => this.result = message);?
-
是的那一行
-
您可以将 dataTrans 声明为公开而不是私有,然后再试一次吗?
-
知道你声明私有 previewdata = new BehaviorSubject('no data');作为对公众的私人更改
-
我试过了,但同样的错误存在