2015-10-25 77 views
3

你好我正在編寫一個chatjs聊天客戶端,並且想要使用從REST調用中獲取的數據呈現我的組件。然而,我的組件在REST請求返回數據之前被渲染;這會導致錯誤,因爲我在我的子組件中調用this.props。

var MainChat = React.createClass({ 
getInitialData: function(){ 
    var c = [] 
    $.get("http://127.0.0.1:8888/test/sampledata.php?user=123", function(data, status) { 
     console.log("Data: "+ data+ "\nStatus: " + status); 
     c = data  
    }) 
}, 
getInitialState: function() { 
    return { 
     chatId : "", 
     chats : this.getInitialData(), 
     //chats: this.props.chats 
    }; 
}, 
handleClickOnLeftUser: function(data){ 
    console.log("handleClickOnLeftUser"); 
    // console.log("chat id is"); 
    // console.log(data.chatID); 
    this.setState({chatID: data.chatID}); 
}, 

render: function() { 
    console.log("main:render") 
    console.log(this.props.chats); 


    var theThreadIWantToPass = {}; 
    for(var i = 0; i < this.state.chats.length; i++) 
    { 
     console.log("chat: " + this.state.chats[i].chatID); 
     if (this.state.chats[i].chatID === this.state.chatID) { 
      theThreadIWantToPass = this.state.chats[i]; 
      break; 
     } 
    } 

    return (
     <div className="chatapp"> 
      <div className="thread-section"> 
       <div className="thread-count"> 

       </div> 
       <LeftUserList 
        chats={this.state.chats} 
        clickFunc={this.handleClickOnLeftUser} // ***important 
       /> 
      </div> 
      <div> 
       <RightMessageBox chat={theThreadIWantToPass} /> 
      </div> 
     </div> 
    ); 
} 
}); 
+2

Laycat,提交了關於要求在同一天的答案來自你的反饋。你現在補充嗎?遲到總比不到好! – halfer

回答

2

在你的情況,你需要使用方法componentDidMount,像這樣

var MainChat = React.createClass({ 

    getInitialData: function() { 
    var url = 'http://127.0.0.1:8888/test/sampledata.php?user=123'; 

    $.get(url, function(data, status) { 
     this.setState({ chats: data });   
    }.bind(this)) 
    }, 

    componentDidMount: function() { 
    this.getInitialData(); 
    }, 

    getInitialState: function() { 
    return { 
     chatId: '', 
     chats: [] 
    }; 
    }, 

    handleClickOnLeftUser: function(data){ 
    this.setState({ chatID: data.chatID }); 
    }, 

    render: function() { 
    var theThreadIWantToPass = {}; 

    for(var i = 0; i < this.state.chats.length; i++) { 
     if (this.state.chats[i].chatID === this.state.chatID) { 
     theThreadIWantToPass = this.state.chats[i]; 
     break; 
     } 
    } 

    return (
     <div className="chatapp"> 
     <div className="thread-section"> 
      <div className="thread-count"></div> 
      <LeftUserList 
       chats={this.state.chats} 
       clickFunc={this.handleClickOnLeftUser} /> 
     </div> 

     <div> 
      <RightMessageBox chat={theThreadIWantToPass} /> 
     </div> 
     </div> 
    ); 
    } 
}); 

注意 - 使用"async": false這是不好的做法

1

發現了一個暫時的問題(至少在某人回答之前)。我目前的解決方案是通過設置

 $.ajaxSetup({ "async": false}) 

來防止jQuery使用回調,然後再調用Jquery的get()函數。

getInitialData: function(){ 
    var c = [] 
    $.ajaxSetup({ "async": false}) 
    $.get("http://127.0.0.1:8888/test/sampledata.php?user=123", function(data, status) { 
     console.log("Data: "+ data+ "\nStatus: " + status); 
     c = data  
    }) 
    return c 
}, 
getInitialState: function() { 
    return { 
     chatId : "", 
     chats : this.getInitialData(), 
     //chats: this.props.chats 
    }; 
}, 
相關問題