2016-06-25 2 views
0

es6 및 jquery의 ajax 함수를 사용하면 this.setState() is not a function 오류가 발생합니다. 나는이 생성자 내에서 this.componentDidmount = this.componentDidmount.bind(this);을 사용하여 바인딩을 시도했지만 여전히 작동하지 않습니다.this.setState()는 componentDidmount 내에서 jquery와 반응 할 때 함수가 아닙니다.

아무도 도와 줄 수 있습니까? 감사!

import React from 'react'; 
import $ from 'jquery'; 

class UserGist extends React.Component { 
    constructor(props) { 
    super(props); 
    this.state = { 
     userName: '', 
     lastGistUrl: '' 
    }; 
    } 

    componentDidMount() { 
    this.serverRequest = $.get(this.props.source, function(result) { 
     let lastGist = result[0]; 
     this.setState({ 
     userName: lastGist.owner.login, 
     lastGistUrl: lastGist.html_url 
     }); 
    }); 
    } 

    componentWillUnmount() { 
    this.serverRequest.abort(); 
    } 

    render() { 
    return(
     <div> 
     {this.state.userName}'s last gist is 
     <a href={this.state.lastGistUrl}>here</a>. 
     </div> 
    ) 
    } 
} 

export default UserGist; 

답변

1

componentDidMount() 내부 콜백 함수에 대한 this 컨텍스트가 설정되지 않은 :

여기 내 코드입니다.

당신은 너무 좋아, 그것을 할 화살표 기능을 사용할 수

this.serverRequest = $.get(this.props.source, (result) => { 
    let lastGist = result[0]; 
    this.setState({ 
    userName: lastGist.owner.login, 
    lastGistUrl: lastGist.html_url 
    }); 
}) 
+0

을 나는'this.componentDidMount = this.componentDidMount.bind (이)를 제거 할 때; this.componentWillUnmount = this.componentWillUnmount.bind (this);'이 함수는 자동으로 'this'를 바인딩합니까? –

+0

예, 모든 React lifecycle 메소드가 자동으로 실행됩니다. 문제는 비동기 코드 인 '콜백 (callback)'함수에서 'this'를 사용하려고했습니다. 자세한 내용은 http://stackoverflow.com/a/20279485/3979621을 참조하십시오. –

+0

@freddy : * "예, 모든 라이프 사이클 메소드가 자동 응답됩니다."* 아니요. React.createClass는 그렇게했지만 class 구문에는 해당되지 않습니다. –

관련 문제