我正在尝试在extractContractsView
中调用此函数。
public getInsurantOrBeneficiary(content_type: number, object_id: number) {
if (content_type == 25) {
this.http.get(AppSettings.API_ENDPOINT + '/api/v1/artifical_persons' + "/" + object_id + "/", this.options)
.map((response: Response) => response.json())
.subscribe((result: any) => {
this.data_name = result;
this.name = this.data_name['name'];
console.log('Artifical persons' + this.name);
return this.name;
});
} else if (content_type == 12) {
this.http.get(AppSettings.API_ENDPOINT + '/api/v1/private_persons' + "/" + object_id + "/", this.options)
.map((response: Response) => response.json())
.subscribe((result: any) => {
this.data_private_persons = result;
this.id_private_persons = this.data_private_persons['passport_id'];
console.log('id_private_persons:' + this.id_private_persons);
});
this.http.get(AppSettings.API_ENDPOINT + '/api/v1/passports' + "/" + this.id_private_persons + "/", this.options)
.map((response: Response) => response.json())
.subscribe((result: any) => {
this.data_name = result;
this.name = this.data_name['second_name'] + ' ' + this.data_name['first_name'] + ' ' + this.data_name['paternal_name'];
console.log('Name in passport:' + this.name);
return this.name;
});
} else if (content_type == 43) {
this.http.get(AppSettings.API_ENDPOINT + '/api/v1/sole_proprietorship' + "/" + object_id + "/", this.options)
.map((response: Response) => response.json())
.subscribe((result: any) => {
this.data_name = result;
this.name = this.data_name['name'];
console.log('sole_proprietorship' + this.name);
return this.name;
});
}
return this.name;
}
问题在于,当我调用getInsurantOrBeneficiary函数时,仅在第一次迭代时才获取数据。但是content_type [i]和object_id [i]始终是不同的,我希望函数返回不同的this.name。 我不太了解异步的工作方式,这可能是this.http.get没时间工作,我只能得到一次答案。
public extractContractsView = (response: Response) => {
let res = response.json();
let contracts: ContractsView[] = [];
for (let i = 0; i < res.length; i++) {
let insurant = this.getInsurantOrBeneficiary(res[i].insurant_id.content_type, res[i].insurant_id.object_id);
let beneficiary = this.getInsurantOrBeneficiary(res[i].beneficiary_id.content_type, res[i].beneficiary_id.object_id);
contracts.push(new ContractsView(
res[i].id,
res[i].treaty_number,
res[i].days_left,
res[i].days_left_before_the_next_payment,
res[i].payment_status_KB,
res[i].security_deposit_no_deposit,
res[i].currency_conversion_only,
res[i].currency,
res[i].contact,
res[i].additional_information,
res[i].prolongation,
res[i].improving_conditions,
res[i].redundancy,
res[i].akt_on_KB,
res[i].payment_status_akt_on_KB,
insurant,
beneficiary,
res[i].insurance_type_id.name,
res[i].insurer_id.name,
res[i].executor_id,
res[i].status,
res[i].payment,
res[i].time_of_action.date_start + ' - ' + res[i].time_of_action.date_end,
res[i].finance,
res[i].date,
res[i].subagent,
res[i].insurance_object,
));
}
return contracts;
}
public getContracts(): Observable<ContractsView[]> {
let contracts = this.http.get(this.url, this.options)
.map(this.extractContractsView)
.catch(this.handleError);
return contracts;
}
感谢您的帮助。
答案 0 :(得分:1)
您将需要重构您的API get调用以返回可观察的对象,并在使用函数中对其进行订阅。您每行要进行两次API调用。您可以使用ForkJoin运算符合并两个调用的结果,然后完成插入到新数组中的操作。我在缩写代码。这应该使您朝正确的方向前进。
public getInsurantOrBeneficiary(content_type: number, object_id: number): Observable<any> {
if (content_type == 25) {
// Return an observable, do not subscribe here
return this.http.get(endpoint, options)
.map((response: Response) => response.json());
}
}
然后在此处订阅并处理:
public extractContractsView = (response: Response) => {
let res = response.json();
let contracts: ContractsView[] = [];
for (let i = 0; i < res.length; i++) {
// Use a forkJoin to combine the results of 2 or more observables
forkJoin(
this.getInsurantOrBeneficiary(),
this.getInsurantOrBeneficiary()
)
.subscribe((result1: any, result2: any) => {
contracts.push(new ContractsView(result1, result2))
});
}
请注意,循环将在返回所有异步结果之前完成。正如评论中指出的那样,这可能不是最佳方法。但是,使用此方法可以实现您想做的事情。