2016-03-21 11 views
1
render: function(){ 
console.log(this.state.search_results); 
var renderedSearchResults = this.state.search_results.map((result) => { 

にconsole.logプリントアレイは次のとおりthis.state.search_results.mapは機能しないが、それは

[{ "ID": "testGroup2"}、{ "ID": " testGroup77777 "}、{" ID ": "testGroup1"}、{" ID ": "testGroup3は"}]

データを介して得られる。

$.ajax({ 
     url: this.props.routes.search, 
     contentType: 'application/json', 
     type: 'POST', 
     data: JSON.stringify(searchObj), 
     success: function(data){ 
      console.log(data); 
      this.setState({search_results:data}); 
     }.bind(this), 
     error: function(xhr, status,err){ 
      console.error("/api/response", status, err.toString()); 
     }.bind(this) 
     });``` 

スルー:

def post(self): 
    """ 
    Makes a request to search for a specific 
    searchtype: Group 
    searchstring: "" 
    requestedfields: [] 
    """ 
    search_type = self.json_data.get('searchtype', 'Group') 
    search_string = self.json_data.get('searchstring', '') 
    requestedfields = self.json_data.get('requestedfields', ['id']) 
    search_model = { 
     'Group': Group(), 
     'User': User() 
    }[search_type] 
    search_fields = { 
     'Group': ['id', 'tags'], 
     'User': ['username'] 
    }[search_type] 
    # check if requestedfields contains valid fields 
    for field in requestedfields: 
     if field == 'id': 
      continue 
     value = search_model.default().get(field, None) 
     if value is None: 
      return self.set_status(400, "Model {0} does not have requested field {1}".format(search_type, field)) 
    try: 
     search_results = search_model.search_items(search_string, search_fields, requestedfields) 
    except err: 
     return self.set_status(400, "Something went wrong") 
    self.set_status(200, "Success") 
    return self.write(tornado.escape.json_encode(search_results)) 

this.state.search_resultsはどのように進行しているのか誰にでも確認できますか?私は成功関数内console.log(Object.prototype.toString.call(data));を使用して試したと私は取得

:私のAJAXリクエストで「JSON」:

[object String] 
+0

JSON.parse(data)を使用して、何を得るかを試してみてください。 –

+0

@ jamesemanon私はそれを見つけた、私は私のajaxリクエストでdataTypeを指定していない –

答えて

1

は、あなたのAJAX要求しながら、明示的な方法でjsonデータタイプを設定してください:おそらく

$.ajax({ 
    dataType: 'json', 
    //... 
}); 

Intelligent GuessのjQueryによるデータ型を検出するために使用され、誤った結果を与えています。

0

は私の答えを見つけて、データ型を設定しませんでした。

関連する問題