json - Angular : ERROR SyntaxError: Unexpected token < in JSON at position 0

标签 json angular http observable

您好,我需要帮助,我创建了一个 Angular 服务,但是当我想查看我的 json 文件中的数据时,它显示了这个错误,我尝试了很多不成功的解决方案

应用程序组件.ts

    import {Component, OnInit} from '@angular/core';
    import {Car} from './domain/car';
    import {CarService} from './service/carservice';

    @Component({
      selector: 'app-root',
      templateUrl: './app.component.html',
      styleUrls: ['./app.component.css'],
      providers: [CarService]
    })
    export class AppComponent implements OnInit {
      cars1: Car[];
      constructor(private carService: CarService) { }

      ngOnInit() {
       this.carService.getCarsSmall().subscribe(cars => this.cars1 = cars);
      }
    }

汽车服务.ts

@Injectable()
export class CarService {

  private jsonUrl = './cars-smalll.json';

  constructor(private http: Http) {}
    getCarsSmall(): Observable<Car[]> {
      return this.http.get(this.jsonUrl)
        .map(this.extractData)
        .catch(this.handleError);
    }

    private extractData(res: Response) {
      let body = res.json();
      return body.data || { };
    }
    private handleError (error: Response | any) {
      // In a real world app, you might use a remote logging infrastructure
      let errMsg: string;
      if (error instanceof Response) {
        const body = error.json() || '';
        const err = body.error || JSON.stringify(body);
        errMsg = `${error.status} - ${error.statusText || ''} ${err}`;
      } else {
        errMsg = error.message ? error.message : error.toString();
      }
      console.error(errMsg);
      return Observable.throw(errMsg);
    }
}

cars-smalll.json

[
    {
      "brand": "VW",
      "year": 2012,
      "color": "Orange",
      "vin": "dsad231ff"
    },
    {
      "brand": "Audi",
      "year": 2011,
      "color": "Black",
      "vin": "gwregre345"
    },
    {
      "brand": "Renault",
      "year": 2005,
      "color": "Gray",
      "vin": "h354htr"
    }
]

提前致谢。

最佳答案

除了使用评论中建议的正确路径外,您的问题是您正试图从不存在的事物中提取数据。看看你的json,它是一个数组。但是在您的 extractData 函数中,您正试图从对象 data 中提取数据,这当然不存在于您的 JSON 中。所以将该函数更改为:

private extractData(res: Response) {
  let body = res.json();
  // return just the response, or an empty array if there's no data
  return body || []; 
}

应该这样做,并更正 JSON 文件的路径。

关于json - Angular : ERROR SyntaxError: Unexpected token < in JSON at position 0,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44170371/

相关文章:

java - 从 Android (WiFi/GPRS) 执行 PHP 脚本的显着运行时差异

python - Flask 不会在 POST 方法上重定向

javascript - JSON 对象创建和 JSON 数组操作

jquery - 如何根据另一个下拉菜单更改下拉菜单值

python - urllib.request.urlopen 的行为很奇怪。第二天不返回数据。为什么?

ios - 从NSJSONSerialization中获取数据中的值

angular - 处理 'handleError ` 和 `extractData` 私有(private)方法的最佳实践

javascript - angular2中多步表单每一步的唯一url

javascript - 如何按 Angular 从本地存储中按日期键删除日期

java - 从输入流中提取内容