如何通过createContainer传递react.js数据,如meteor.js或relay.js

时间:2017-02-28 20:32:56

标签: javascript node.js reactjs meteor relayjs

我喜欢从meteor和react.js接收relay.js数据的概念。 例如meteor.js,在createContainer中,我从localstorage获取数据:

class App extends Component {
  render(){
    return (<div>{this.props.doc}</div>);
  }
}
export default createContainer( () => {
  subscribe('doc');
  return { doc:Docs.find() };
}, App);

或示例表单relay.js,其中createContainer数据数据来自graphQL分配的props

class App extends React.Component {
  render() {
    var name = this.props.tea;
    return (<li key={name}>{name}</li>);
  }
}
App = Relay.createContainer(App, {
  fragments: {
    tea:() => Relay.QL`fragment on Tea {name}`,
  },
});

如何制作一个从websocket接收数据的功能? 我可以想象这样的代码:

class App extends Component {
  render(){
    return (<div>{this.props.doc}</div>);
  }
}
export default createContainer( () => {
  return { doc:Docs.find() };
}, App);

ReactDOM.render(<App>, document.getElementById('root'));


function createContainer(options, callback) { 
   var props;
   var socket = new WebSocket("ws://localhost:8081");
   socket.onmessage = function(event) {
       props = event.data;
   };
   <callback data={props}>
}

我不完全明白如何最好写,所以请帮忙。

1 个答案:

答案 0 :(得分:0)

我看起来在meteor.js中工作了。我理解它应该如何运作。只需要创建一个返回react.js组件的函数。并传递参数和组件本身以及所有参数。在createContainer函数中,已经可以从websockets获取数据或从indexDB中取出数据。

如果非常简单,它可能如下所示:

import React from 'react';
export default function createContainer(options = {}, Component) {
  return React.createClass({
    displayName:'DataContainer',    
    render() { return <Component data=options />; },
  });
}

流星中组件的完整代码如下:

https://github.com/jedwards1211/react-meteor-data/blob/master/src/createContainer.js