首页 文章

IONIC v3获取CoinMArketCap API数据

提问于
浏览
0

我想在离子的帮助下显示市场上所有可用的加密硬币列表 .

我为此使用了coinmarketcap api . https://coinmarketcap.com/api/

我已经推荐了这个教程 - > https://www.djamware.com/post/59924f9080aca768e4d2b12e/ionic-3-consuming-rest-api-using-new-angular-43-httpclient

我面临的问题是我无法列出所有硬币 . 我能够从api检索数据,但我想在显示数据时存在问题 .

Data returned by api

{
    "data": [
        {
            "id": 1, 
            "name": "Bitcoin", 
            "symbol": "BTC", 
            "website_slug": "bitcoin"
        }, 
        {
            "id": 2, 
            "name": "Litecoin", 
            "symbol": "LTC", 
            "website_slug": "litecoin"
        }, 
        ...
    },
    "metadata": {
        "timestamp": 1525137187, 
        "num_cryptocurrencies": 1602, 
        "error": null
    }
]

Error Occurred

ERROR错误:无法找到'object'类型的不同支持对象'[object Object]' . NgFor仅支持绑定到诸如Arrays之类的Iterables . (MarketPage.html 18)

at NgForOf.ngOnChanges (VM5532 vendor.js:45147)
at checkAndUpdateDirectiveInline (VM5532 vendor.js:12781)
at checkAndUpdateNodeInline (VM5532 vendor.js:14309)
at checkAndUpdateNode (VM5532 vendor.js:14252)
at debugCheckAndUpdateNode (VM5532 vendor.js:15145)
at debugCheckDirectivesFn (VM5532 vendor.js:15086)
at Object.eval [as updateDirectives] (VM5623 MarketPage.ngfactory.js:56)
at Object.debugUpdateDirectives [as updateDirectives] (VM5532 vendor.js:15071)
at checkAndUpdateView (VM5532 vendor.js:14218)
at callViewAction (VM5532 vendor.js:14569)

Rest.ts

import { HttpClient } from '@angular/common/http';
import { Injectable } from '@angular/core';
import { Observable } from 'rxjs/Observable';
@Injectable()
export class RestProvider {

apiUrl = 'https://api.coinmarketcap.com/v2'; 

constructor(public http: HttpClient) {
console.log('Hello RestProvider Provider');
}

getAllCoinsListing() {
return new Promise(resolve => {
  this.http.get(this.apiUrl+'/listings').subscribe(data => {
    resolve(data);
  }, err => {
    console.log(err);
  });
});
}
}

Market.ts

import { Component } from '@angular/core';
import { NavController } from 'ionic-angular';
import { RestProvider } from '../../providers/rest/rest';

@Component({
  selector: 'page-market',
  templateUrl: 'market.html'
})
export class MarketPage {

  marketData: any;

  constructor(public navCtrl: NavController, public restProvider: 
           RestProvider) {
          this.getAllCoinsListing();
  }

  getAllCoinsListing() {
     this.restProvider.getAllCoinsListing()
     .then(data => {
      this.marketData = data;
     });
  }

}

MarketPage.html

<ion-content>
    <ion-list inset>
         <ion-item *ngFor="let data of marketData">
             <h2>{{data.name}}</h2>
             <p>{{data.name}}</p>
         </ion-item>
     </ion-list>
 </ion-content>

1 回答

  • 0

    建议使用 Observables over promises . 通过转换为承诺,您将失去取消请求的能力以及链接 RxJS 运算符的能力 .

    Modified code:

    import { HttpClient } from '@angular/common/http';
    import { Injectable } from '@angular/core';
    import { Observable } from 'rxjs/Observable';
    import 'rxjs/add/operator/map';
    @Injectable()
    export class RestProvider {
    
    apiUrl = 'https://api.coinmarketcap.com/v2/listings/'; 
    
    constructor(public http: HttpClient) {
    console.log('Hello RestProvider Provider');
    }
    
    getAllCoinsListing() {
    
     return this.http.get(this.apiUrl).map(res=>{return res['data']});//return data of result
    }
    }
    

    Market.ts

    import { Component } from '@angular/core';
            import { NavController } from 'ionic-angular';
            import { RestProvider } from '../../providers/rest/rest';
    
                @Component({
                  selector: 'page-market',
                  templateUrl: 'market.html'
                })
                export class MarketPage {
    
                  marketData: Array<any>=[];
                 //your API returns an array of object
    
                  constructor(public navCtrl: NavController, public restProvider: 
                           RestProvider) {
                          this.getAllCoinsListing();
                  }
    
                 getAllCoinsListing() {
               this.restProvider.getAllCoinsListing().
            subscribe(data=>this.marketData=data);
    
      }
    
                }
    

    Live Demo

相关问题