2

Flux ストアのデータ オブジェクトをどのように初期化しますか?

class MyStore {
   constructor() {
      this.myData = {}; 
      // or
      this.myData = null;
   }

   onReceiveData(data) {
      this.myData = data;
   }
}

私のReactコンポーネントでは、データがサーバーからロードされて子をレンダリングするかどうかを確認しています:

render() {
    // <Child /> has required props in `data` object
    return (
        <div>
            {!this.state.myData ? (
               <div>Loading...</div>
            ) : (
               <Child data={this.state.myData} />
            )}
        </div>
    )
}
4

2 に答える 2

4

AppBootstrap.js モジュールを使用して、(1) ストアをインスタンス化し、(2) サーバーからの初期データを使用して初期化アクションをディスパッチし、(3) ルート React コンポーネントをレンダリングします。

例:

// AppBootstrap.js

var AppConstants = require('AppConstants');
var AppDispatcher = require('AppDispatcher');
var AppRoot = require('AppRoot.react');
var React = require('React');

require('FriendStore');
require('LoggingStore');
require('MessageStore');

module.exports = (initialData, elem) => {
  AppDispatcher.dispatch({
    type: AppConstants.ActionTypes.INITIALIZE,
    data: initialData
  });
  React.render(<AppRoot />, elem);
};
于 2015-03-05T19:02:13.417 に答える
1

ビューは、フラックス構造に従って、ストア データの変更を常にリッスンする必要があります。したがって、ストアにデータがあるかどうかをビューでチェックするべきではありません。代わりに、Store は、データが変更されたことをビューに通知する必要があります。

例:

var ActionConstants = require('../constants/action-constants.js');
var AppDispatcher = require('../dispatcher/app-dispatcher.js');
var React = require('react');
var EventEmitter = require('events').EventEmitter;

var MyStore = assign({}, EventEmitter.prototype, {
  items_: [],

  emitChange: function() {
    this.emit(ActionConstants.stores.DATA_CHANGED);
  },

  addChangeListener: function(callback) {
    this.on(ActionConstants.stores.DATA_CHANGED, callback);
  },

  removeChangeListener: function(callback) {
    this.removeListener(ActionConstants.stores.DATA_CHANGED, callback);
  }
});

MyStore.dispatchToken = AppDispatcher.register(function(payload) {
  switch(payload.type) {
    // Handle store initiation on action result received.
    // Also broadcast the data change event to listeners.
    case ActionConstants.MyStoreInit:
      MyStore.init(payload.data);
      MyStore.emitChange();
  }
}
于 2015-03-12T23:51:41.243 に答える