Angular DataService не может разрешить параметры - PullRequest
0 голосов
/ 28 мая 2018

Я использую Angular v.4.2.4.Когда я пытаюсь получить данные из API, у меня появляется ошибка, которую я не могу найти.API находится на моей собственной машине и возвращает данные, как это должно быть в почтальоне.Я получаю ошибку:

Can't resolve all parameters for DataService

Вот мои файлы, которые, как я думал, помогут найти ошибку:

app.module

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { HttpClientModule } from '@angular/common/http';    

import { AppComponent } from './app.component';
import { ProductComponent } from './shop/product.component';
import { DataService } from './shared/dataService';

@NgModule({
    declarations: [       
        AppComponent,
        ProductComponent
    ],
    imports: [
        BrowserModule,
        HttpClientModule
    ],
    providers: [DataService],
    bootstrap: [AppComponent]
})
export class AppModule { }

dataService

import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { Observable } from 'rxjs';
import 'rxjs/add/operator/map';
import { Product } from './product';

Injectable()
export class DataService {

    constructor(private http: HttpClient) { }

    public products: Product[] = [];

    loadProducts(): Observable<boolean>{
        return this.http.get('/api/products')
            .map((data: any[]) => {
                this.products = data;
                return true;
            })
    }
}

product.component

import { Component, OnInit } from "@angular/core";
import { DataService } from '../shared/dataService';
import { Product } from '../shared/product';  


@Component({
    selector: "product-list",
    templateUrl: "productList.component.html",
    styleUrls: []
})

export class ProductComponent implements OnInit {

    constructor(private data: DataService) { }

    public products: Product[] = [];

    ngOnInit(): void {
        this.data.loadProducts()
            .subscribe(success => {
                if (success) {
                    this.products = this.data.products;
                }
            });
    }
}

Скажите, хотите ли вы увидетьчто-нибудь еще.Спасибо за помощь.

1 Ответ

0 голосов
/ 28 мая 2018

вам необходимо указать какое-либо значение данных в качестве параметра в вашем «product» API в компоненте продукта.

this.data.loadProducts({'url': '/api/products', 'data':{
'x': ''
}}).subscribe(success =>{
console.log(success);
})

в вашем dataService

loadProducts(data): Observable<boolean>{
    return this.http.get(data.url, data.data)
        .map((data: any[]) => {
            this.products = data;
            return true;
        })
}
...