首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MeteorJS和AmplifyJS reactive

MeteorJS和AmplifyJS reactive
EN

Stack Overflow用户
提问于 2012-11-15 02:49:03
回答 2查看 1.1K关注 0票数 2

所以我使用的是用于meteor的amplifyjs包。

我对meteor还是个新手,很难让它成为一个响应式的上下文。

我正在使用

代码语言:javascript
复制
amplify.store( string key )

因此,当我对其进行更改或添加值时,我希望视图更新能够反映这一点。

我想我将不得不使用Meteor.deps或自动订阅,但不确定从哪里开始。任何帮助都是最好的。

EN

回答 2

Stack Overflow用户

发布于 2012-12-14 10:00:11

由于amplify是一个第三方包,它不使用Meteor上下文,也不具有内置的反应性。但是您可以很容易地构建自己的反应式包装器。您可以查看deps文档,了解如何使用Meteor.deps.Context和Meteor.deps._ContextSet执行此操作:

http://docs.meteor.com/#meteor_deps

我还在这里发布了一个视频教程:http://www.eventedmind.com/posts/reactivity-with-contexts

票数 4
EN

Stack Overflow用户

发布于 2013-02-02 13:52:05

实际上,您可以做的是创建Session的“子类”,在调用set()时将值存储在Amplify的存储中。您将自动继承Session的所有反应属性。下面是代码,它对我很有效:

代码语言:javascript
复制
SessionAmplify = _.extend({}, Session, {
  keys: _.object(_.map(amplify.store(), function(value, key) {
    return [key, JSON.stringify(value)]
  })),
  set: function (key, value) {
    Session.set.apply(this, arguments);
    amplify.store(key, value);
  },
});

只需将所有Session.set/get调用替换为SessionAmplify.set/get调用即可。当调用set()时,父会话方法和amplify.store()都会被调用。当"subclass“第一次被创建时,它会在它的键中加载amplify的store中的所有内容。

您可以在这里测试排行榜示例的工作变体:https://github.com/sebastienbarre/meteor-leaderboard

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13385299

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档