gpt4 book ai didi

javascript - meteor :Tracker.autorun/observeChanges 和集合未按预期工作

转载 作者:可可西里 更新时间:2023-11-01 09:24:30 35 4
gpt4 key购买 nike

我是 meteor 的新手,所以我希望得到关于这些功能如何工作以及我应该如何使用它们的非常基本的解释。否则,如果有一种方法更适合我希望实现的目标,我将不胜感激。

我希望实现的功能:

我有一个 Mongo 集合,其中包含分配给特定用户的文档中的数字值。

我将使用从文档中获取的值来填充宽度:xx% 在“进度条”上的某些 css 内联样式中。但我对它的另一个用途是执行某种“ react 性”功能,每当此值更改时运行,它可以根据进度条的当前值动态更新此进度条的背景颜色。认为“红色”代表低,“绿色”代表高:

元素.html:

<template name="progressBar">
<div id="progress-bar" style="width:{{curValue}}; background-color:*dynamicColor*;"></div>
</template>

元素.js:

Progress = new Mongo.Collection("progress");

Template.progressBar.helpers({
curValue: function () {
return Progress.findOne({user: Meteor.userId()}).curValue;
}
});

上述有时有效。但它似乎并不可靠,现在对我不起作用。我收到有关无法读取未定义的属性“curValue”的错误。根据我在网上的研究,这意味着我试图在集合加载之前访问该文档。但我真的找不到直接的解决方案,也无法全神贯注地思考我应该如何构建它以避免该错误。

下一个问题是观察该值的变化并运行一个函数来更改背景颜色(如果确实发生变化)。

以下是我尝试使用的一些自动运行/观察代码片段:

Session.set('currentValue', Progress.findOne({user:Meteor.userId()}).curValue);
Tracker.autorun(function(){
var currentValue = Session.get('currentValue');
updateColor(currentValue);
});

var currentValue = Progress.findOne({user:Meteor.userId()}).curValue);
var handle = currentValue.observeChanges({
changed: function (id, currentValue) {
updateColor(currentValue);
}
});

总结问题/问题:

我想在一些内联 CSS 中使用来自 mongo 数据库文档的值,并跟踪该值的变化。当值发生变化时,我希望运行一个函数来更新 div 的背景颜色。


更新

使用下面@Ethaan 的回答,我能够更正我对收集数据的订阅/模板使用。我做了更多的挖掘,对发布/订阅方法有了更深入的了解,并学习了如何在我的集合加载后的适当时间正确使用订阅回调来运行我的 Tracker.autorun 函数。我能够扩展下面给我的答案,包括一个响应式(Reactive) Tracker.autorun,它将为我运行一个函数,根据我的文档值更新我的颜色。

我最终得到的代码如下:

元素.js

if (Meteor.isClient) {

Progress = new Mongo.Collection("progress");

Template.content.onCreated(function () {
var self = this;

self.autorun(function () {
self.subscribe("progress", function(){
Tracker.autorun(function(){
var query = Progress.findOne({user: Meteor.userId()}).level;
changeColor(query);
});
});
});
});

Template.content.helpers({
value: function(){
return Progress.findOne({user: Meteor.userId()}).level;
}
});

function changeColor(value){
//run some code
}

}

if (Meteor.isServer) {

Progress = new Mongo.Collection("progress");

Meteor.publish("progress", function () {
return Progress.find({user: this.userId});
});

}

元素.html

<head>
<title>Project</title>
</head>

<body>
{{> standard}}
</body>

<template name="standard">
...
{{> content}}
</template>

<template name="content">
{{#if Template.subscriptionsReady}}
{{value}}
{{else}}
0
{{/if}}
</template>

最佳答案

that means that I am trying to access this document before the collection has loaded

看来您遇到了问题,现在让我们开始寻找一些可能的解决方案。

Meteor 1.1 版

如果您使用的是新的 meteor 1.1 版(您可以检查运行 meteor --version)

使用这个。

首先在 onCreated 函数上使用它。

Template.progressBar.onCreated(function () {
var self = this;

self.autorun(function () {
self.subscribe("Progress");
});
});

查看更多关于 subscriptionReady 的信息在文档上。现在在 HTML 上这样使用。

<template name="progress">
{{#if Template.subscriptionsReady}}
<div id="progress-bar" style="width:{{curValue}}; background-color:*dynamicColor*;"></div>
{{else}}
{{> spinner}} <!-- or whatever you have to put on the loading -->
{{/if}}
</template>

1.0.4下的Meteor

您可以在路由器上安装类似于 waitOn:function(){} 的东西

waitOn:function(){
Meteor.subscribe("Progress");
}

因为助手是异步的,所以做这样的事情(不推荐)。

Template.progressBar.helpers({
curValue: function () {
query = Progress.findOne({user: Meteor.userId()}).curValue;
if(query != undefined){
return query;
}else{
console.log("collection isn't ready")
}
}
});

关于javascript - meteor :Tracker.autorun/observeChanges 和集合未按预期工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29443513/

35 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com