wildreact

0.1.1 • Public • Published

QUICK START

WildReact

ReactJS 是一个用于构建大型、复杂用户界面的框架。Wilddog 开发的插件可以为 React 组件的状态迁移提供一个完美易用而且实时的数据源。 使用 WildReact 仅需数行 JavaScript 代码便可将 Wilddog 集成到 React 应用中。

第一步 创建账号和应用

参见 JavaScript SDK 快速入门 应用创建一节。

第二步 引入 Wilddog JavaScript SDK 和 WildReact

为了在我们的应用当中使用 WildReact,需要加入一些别的依赖到 <head> 中,我们建议你直接使用 Wilddog 所提供的CDN:

<!-- React JS -->
<script src="https://fb.me/react-0.13.3.js"></script>
<script src="https://fb.me/JSXTransformer-0.13.3.js"></script>

<!-- Wilddog JavaScript SDK -->
<script src = "https://cdn.wilddog.com/sdk/js/current/wilddog.js" ></script>

<!-- WildReact -->
<script src = "https://cdn.wilddog.com/libs/wildreact/0.1.0/wildreact.js" ></script>  

你也可以使用 npm install wildreact 来安装 WildReact 和它的所有依赖

第三步 使用 WildReact

使用 WildReact 与普通的 React mixin 组件没有什么不同,不过,我们为它添加了几个使用 Wilddog 所需要的特殊方法。 这些方法使得我们能够让 Wilddog 中的数据与 React 组件的 this.state 变量之间建立绑定关系。 添加 WildReact 到我们组件的 mixins 列表中:

var ExampleComponent = React.createClass({
  mixins: [WildReactMixin],
  ...
});

第四步 绑定到 Wilddog

由于 WildReactMixin 所提供的数据绑定功能,远端数据库中的任何变化都会被实时反映到 this.state 中。反过来的话这种绑定关系是无效的——直接对this.state 所做的修改并不会反映到远端数据库中。 我们想对 this.state 做任何修改时都应该通过调用 Wilddog 客户端的 API 来完成,WildReactMixin 会察觉到远端数据库的变化并更新 this.state

WildReactMixin建立的是一种从远端数据库到我们组件的单向数据绑定关系

拿上面的 ExampleComponent 举例来说,我们可以通过在组件的 componentWillMount() 方法中使用 WildReactMixin 使得远端的数据库某个 items 节点的任何改变与我们组件的 this.state.items 保持同步:

componentWillMount: function() {
  var ref = new Wilddog("https://<YOUR-Wilddog-APP>.wilddogio.com/items");
  this.bindAsArray(ref, "items");
}

现在,如果我们在远端数据库向 items 节点下添加一个新数据,那么这个变化会被自动反映到 this.state.items 中。我们可以选择将远端数据同步为 JavaScript 数组(使用 bindAsArray())或是对象(使用 bindAsObject()) 。

第五步 取消对 Wilddog 的绑定

当我们的 React 组件将超出范围或被卸载时,WildReactMixin 将会自动取消对于所有处于打开状态的 Wilddog 连接的绑定。如果我们想更早一些手动执行这个操作(即在组件仍处于挂载状态时),WildReactMixin 提供了一个 unbind() 方法。例如,当我们不再想要 this.state.items 被绑定到远端数据节点,我们可以在组件中的任何地方调用 this.unbind("items")

下一步

开发向导

开发向导

API文档

API文档

Package Sidebar

Install

npm i wildreact

Weekly Downloads

8

Version

0.1.1

License

MIT

Last publish

Collaborators

  • starport.ops