0

这是我在其中一个模板中的简化版本:

{{#each dataRecord}}

{{#if editingNow}}

  <tr class="dataRow">
    <td><button class="updateRecord" id="{{this._id}}">SAV</button></td>
    <td><input type="text" id="{{this._id}}" value="{{this.f}}"></td></td>
  </tr>

  {{else}}

  <tr class="dataRow">
    <td><button class="edit" id="{{this._id}}">EDIT</button></td>
    <td>{{this.f}}</td> 
    <td><button class="deleteRecord" id="{{this._id}}">DEL</button> </td>
  </tr>

{{/if}}

{{/each}}

editingNow 返回布尔会话变量的值,该变量以 false 开头。因此,当页面加载时,用户会看到每条记录的“f”字段的值和“编辑”按钮。EDIT 按钮将会话变量翻转为 true,然后使用输入元素显示数据。用户可以编辑数据并单击该按钮,该按钮现在是一个“保存”按钮。该按钮使用 _id 更新记录并将会话变量翻转回 false。

就编辑数据而言,这项工作 - 记录肯定会得到更新。我可以检查控制台中的值并查看它是否已更改。但是表中显示的数据会恢复为原始值。我可以非常短暂地看到该字段中显示的更改,然后它会翻转回来。更奇怪的是,如果我再次单击 EDIT 按钮,表格仍会显示旧值。在该字段中查看更新数据的唯一方法是重新启动应用程序。

当我使用本地 mongo db 或链接到meteor.com 上的数据库时,这个问题从未发生过。自从我将我的应用程序移至modules.io 后,这种情况才开始发生。有任何想法吗?

更新 虽然我无法弄清楚是什么导致了模板中的反应更新问题,但在 Ethaan 的帮助下,我能够更好地理解这个问题并找到解决方法,所以我接受了答案,希望我们最终会追根溯源。

4

1 回答 1

2

好像你有一些allow/deny问题?

尝试

Collection.allow({
 insert:function(){return true;},
 remove:function(){return true;},
 update:function(){return true;},
})

或者检查与数据库的连接是否成功,进入模数管理面板

选项 2

清理数据库并在服务器端进行虚拟插入。

先上流星壳跑meteor reset

或者,如果您的应用程序位于模数.io 上,请使用mongo shell, 并使用这段代码。

db.getCollectionNames().forEach(function(name) {
  if (name.indexOf('system.') === -1) {
    db.getCollection(name).drop();
  }
})

现在,当您确定数据库为时,将其放在服务器端。

//Server Code.
    Meteor.startup(function(){
      if(Collection.find().count() == 0){
        Collection.insert({serverInsert:"test from server"},function(err,result){
         if(!err){
          console.log("insert succefull")
        }
     })
    }
  })
于 2015-04-01T16:06:31.663 回答