На моем пути к обучению React и ES6 я взял официальный учебник и поиграл, чтобы сделать его совместимым с ES6. Но когда дело доходит до выполнения запроса Ajax, я получаю следующее сообщение об ошибке:Почему this.props undefined в моем коде ReactJS?
CommentBox.js:23 Uncaught TypeError: Cannot read property 'url' of undefined
Вот мой CommentBox файл/код:
import React from 'react';
import CommentList from './CommentList.js';
import CommentForm from './CommentForm.js';
export default class CommentBox extends React.Component {
constructor(props) {
super(props);
console.log(this.props)
this.state = {
data: []
}
}
loadCommentsFromServer() {
$.ajax({
url: this.props.url,
dataType: 'json',
cache: false,
success: function(data) {
this.setState({data: data});
}.bind(this),
error: function(xhr, status, err) {
console.error(this.props.url, status, err.toString());
}.bind(this)
});
}
handleCommentSubmit(comment) {
let comments = this.state.data;
// Optimistically set id on the new comment.
// It will be replaced by an id generated by the server.
// In a production you would have a more robust system in place.
comment.id = Date.now();
let newComments = comments.concat([comment]);
this.setState({data: newComments});
$.ajax({
url: this.props.url,
dataType: 'json',
type: 'POST',
data: comment,
success: function(data) {
this.setState({data: data});
}.bind(this),
error: function(xhr, status, err) {
this.setState({data: comments});
console.error(this.props.url, status, err.toString());
}.bind(this)
});
}
componentDidMount() {
this.loadCommentsFromServer();
setInterval(this.loadCommentsFromServer, this.props.pollInterval);
}
render() {
return (
<div className="commentBox">
<h1>Comments</h1>
<CommentList data={this.state.data} />
<CommentForm onCommentSubmit={this.handleCommentSubmit} />
</div>
);
}
}
ошибка произойдет на loadCommentsFromServer
; кажется, не знает, что такое this.props
. Я думал, что это была эта ссылка проблема и нашел similar question, где для устранения проблемы предлагается использовать новые стрелки ES6. Затем я попробовал: loadCommentsFromServer =() => {}
, но Browserify жалуется и не строит.
Возможный дубликат [Как получить доступ к правильному \ 'this \'/context внутри обратного вызова?] (Http://stackoverflow.com/questions/20279484/how-to-access-the-correct-this-context -indide-a-callback) –
См. «Общая проблема: использование объектных методов в качестве обратных вызовов/обработчиков событий» в предлагаемом дубликате. –
Вам необходимо связать его вручную. ES6 класс не autobind – thangngoc89