zone.js: 2969 GET http://localhost:4200/null 404 (не найдено) - PullRequest
0 голосов
/ 31 мая 2018

В настоящее время я работаю над очень простым угловым проектом, использующим service.ts для получения http-данных из файла .json, но при его запуске ошибка CLI отсутствует, но консоль браузера показывает это:

zone.js: 2969 GET http://localhost:4200/null 404 (не найдено)

Вот мой app.module.ts

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { CarouselModule } from 'ngx-bootstrap/carousel';
import { NO_ERRORS_SCHEMA } from '@angular/core';
import { HttpModule } from '@angular/http';
import { AppComponent } from './app.component';
import { ObservableComponent } from './observable/observable.component';
import { UserDataService } from './userdata.service';

@NgModule({
  declarations: [
    AppComponent,
    ObservableComponent
  ],
  imports: [
    BrowserModule,
    CarouselModule.forRoot(),
    HttpModule
  ],
  providers: [UserDataService],
  schemas: [ NO_ERRORS_SCHEMA ],
  bootstrap: [AppComponent],

})

export class AppModule { }

app.component.ts:

import { Component } from '@angular/core';
import { setTheme } from 'ngx-bootstrap/utils';


@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
    constructor() {
        setTheme('bs4');
    }

}

index.html:

<!doctype html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Eshop</title>
  <base href="/src">

  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="icon" type="image/x-icon" href="favicon.ico">
  <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet">  
</head>
<body>
  <app-root></app-root>  
</body>
</html>

app.component.html:

<div>   
    <app-observable></app-observable>   
</div>

userdata.service.ts:

import { Injectable } from '@angular/core';
import { Http, Response } from '@angular/http';
import {Observable} from 'rxjs';
import { map } from "rxjs/operators";
import { catchError } from 'rxjs/operators';
import { Data } from './userdata';
import { throwError } from 'rxjs';

@Injectable()
export class UserDataService {

  url : "http://localhost:4200/assets/data/userdata.json";
  constructor(private http:Http) { }  

  getDataWithObservable() : Observable<Data[]>{
      return this.http.get(this.url)
            .pipe(
              map(this.extractData),
              catchError(this.handleErrorObservable)
            );
  }

    private extractData(res: Response) 
    {
        let body = res.json();              
        return body;
    }

    private handleErrorObservable (error: Response | any) 
    {   
        return throwError(error.message || error);
    }
}

observable.component.html:

<br><h3>User Details with Observable</h3>
<ul>
  <li *ngFor="let data of mydata | async" >
    Id: {{data.id}}, Name: {{data.name}}
  </li>
</ul>

<div *ngIf="errorMessage"> {{errorMessage}} </div> <br>

userdata.ts:

export class Data {
   id: number;
   name: string;
   constructor() { }
} 

observable.component.ts:

import { Component, OnInit } from '@angular/core';
import { Observable } from 'rxjs';
import { UserDataService } from '../userdata.service';
import { Data } from '../userdata';

@Component({
  selector: 'app-observable',
  templateUrl: './observable.component.html',
  styleUrls: ['./observable.component.css']
})
export class ObservableComponent implements OnInit 
{   
    ObservableData :  Observable<Data[]>;
    mydata : Data[];
    errorMessage : String;

    constructor(private userdataService: UserDataService) { }

    ngOnInit(): void 
    {
        this.ObservableData = this.userdataService.getDataWithObservable();     
        this.ObservableData.subscribe
        (     
            mydata => this.mydata = mydata,
            error =>  this.errorMessage = <any>error
        );              
    }   
}

userdata.json:

[
  {"id": 1, "name": "Jack"},
  {"id": 2, "name": "Maddy"},
  {"id": 3, "name": "Hiten"},
  {"id": 3, "name": "Jitendra"}
]  

Это все мои файлы моего проекта ...

Кто-нибудь может подсказать, что должно быть сделано?

1 Ответ

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

Вы неправильно инициализируете переменную URL.Учтите, что в TypeScript синтаксис:

varName: varType;

Измените ваш userdata.service.ts в соответствии с этим:

@Injectable()
export class UserDataService {

  private url: string;

  constructor(private http: Http) {
    this.url = 'http://localhost:4200/assets/data/userdata.json';
  }

  getDataWithObservable(): Observable<Data[]> {
    return this.http.get(this.url)
      .pipe(
        map(this.extractData),
        catchError(this.handleErrorObservable)
      );
  }

  private extractData(res: Response)
  {
    let body = res.json();
    return body;
  }

  private handleErrorObservable (error: Response | any)
  {
    return throwError(error.message || error);
  }
} 

В противном случае, если вы хотите напрямую инициировать переменную url, вы можете действовать следующим образомthis:

private url: string = 'http://localhost:4200/assets/data/userdata.json';

Или вы можете опустить определение типа следующим образом:

private url = 'http://localhost:4200/assets/data/userdata.json';

Обратите внимание, что в отличие от вашего кода назначение выполняется с помощью =

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...