2016-10-02 13 views
0

私はJSONPプロキシを経由してデータをロードすると仮定され、次の店があります。ブラウザのネットワークタブからExtJS:JSONPプロキシからの応答を取得していますか?

Ext.define('Forecaster.store.WeatherDay', { 
    extend : 'Ext.data.Store', 
    model : 'Forecaster.model.WeatherDay', 
    autoLoad : true, 
    proxy : { 
     type : 'jsonp', 
     method : 'GET', 
     url : 'http://api.wunderground.com/api/[myAPIKey]/forecast10day/q/11432.json', 
     root: 'forecast', 
     dataType : 'json', 
     success: function (result, request) { 
      //success 
      console.log("Sucess!"); 
      console.log(result, request); 
     } 
    } 
}); 

を、私は(切り捨て)レスポンスが返ってくることを参照してください。

Ext.data.JsonP.callback1(
{ 
    "response": { 
    "version":"0.1", 
    "termsofService":"http://www.wunderground.com/weather/api/d/terms.html", 
    "features": { 
    "forecast10day": 1 
    } 
    } 
     , 
    "forecast":{ 
     "txt_forecast": { 
     "date":"5:18 PM EDT", 
     "forecastday": [ 
     { 
     "period":0, 
     "icon":"cloudy", 
     "icon_url":"http://icons.wxug.com/i/c/k/cloudy.gif", 
     ...more of the response... 

しかし、上記のコールバック関数は実行されていないようです。 JSONレスポンスを得るには何が必要ですか?

答えて

2

プロキシに「成功」​​設定はありません(http://docs.sencha.com/extjs/6.0.2/classic/Ext.data.proxy.JsonP.htmlを参照)。

ストアクラスを定義したら、それを作成してからload関数を呼び出す必要があります。 このように

var store = Ext.create('Forecaster.store.WeatherDay'); 
store.load({ 
     success: function (result, request) { 
      //success 
      console.log("Sucess!"); 
      console.log(result, request); 
     } 
}); 
関連する問題