ES5
에서 잘 작동하는 React
모듈이 있습니다. 나는 그것을 ES6
으로 변환하고 변환을 위해 6to5
을 사용하고있다. 모든 것은 잘 처리되지만, props
을 설정할 때 런타임 오류가 발생합니다. debugger
을 삭제하고 this
을 보면 this
은 EventEmitter
이며 클래스가 아닙니다. 여기 내 코드는 다음과 같습니다.React 모듈을 ES6 클래스로 변환 할 때`this '를 해결하는 방법
var React = require('react');
import CalendarStore from './../stores/calendar.store.js';
function getAppointments() {
return {appts: CalendarStore.getAppts()}
}
export default class extends React.Component{
constructor(props) {
super(props);
this.props = {
view: 'weeks'
}
}
changeView(child, view) {
this.setProps({view: view});
}
componentWillMount() {
CalendarStore.addChangeListener(this._onChange);
}
_onChange() {
this.setProps(getAppointments());
}
....
};
내 changeView
기능에있는 곳입니다. 그것은 다음과 같습니다 transpiled
아래 인 경우 :
_onChange: {
value: function _onChange() {
this.setProps(getAppointments());
},
writable: true,
configurable: true
}
다시는, 그 함수 내에서, this
내 EventEmitter
입니다. 이 문제를 해결하는 방법은 무엇입니까?
믹스 인으로 점포를 처리하는 방법을 설명하는 블로그 나 어딘가에 표시 할 수 있습니까? – jhamm
대부분의 플럭스 구현은 하나의 플럭스 구현을 제공합니다. mixin은 저장소에서 초기 상태를 가져 와서 저장소를 청취하고 변경 사항이있을 때 this.setState를 처리합니다. 또한 구성 요소가 마운트 해제 될 때 청취자를 정리합니다. 다음은 [fluxx 또는 store mixin] (http://fluxxor.com/documentation/store-watch-mixin)의 예입니다.html) – FakeRainBrigand
@FakeRainBrigand 만약 내가 또한 흐름을 사용하고 이것과 같은 기본값을 설정한다면? '_value에 할당 됨 ' – tsm