3

我是 angular-meteor 应用程序开发的新手,我正在努力从客户端对数据库进行更改。我已经成功完成了大部分angular-meteor 教程,但是现在我正在尝试开始一个新项目并调整教程中的概念,我遇到了问题。

问题。 用户填写表格,当他们点击“添加”时,表格应该将数据保存到数据库中。在同一页面上,我包含了一个显示所有数据库条目的列表(html 列表中的典型“元素中的元素”循环)。但是,当我在填写表格后单击“添加”时,新条目会在一瞬间添加到列表中,然后消失。当我单击“全部删除”按钮时会发生相同的行为,一切都会消失一会儿然后恢复。持久化的数据是添加/删除之前数据库中的任何内容。

尝试排除故障。我可以使用“meteor mongo”访问该集合,并且持久存在的值在该集合中。我可以从命令行添加到集合或从中删除(编辑:更改会反映在客户端)。在客户端提交的条目不会添加到数据库中。我使用带有条件的服务器端启动功能启动了数据库if (Videos.find().count() === 0)。我认为也许数据库每次都只是重新初始化自己,但是当初始化代码被注释掉时,这种行为仍然存在。添加自动发布项目并不能解决问题。编辑:谷歌浏览器在提交之前或之后在控制台中没有任何错误。

相关代码。我使用这个存储库作为起点。

/client/views/submit/submit.controller.js

angular.module("app").controller("SubmitCtrl", ['$scope', '$meteor',
  function($scope, $meteor){

    $scope.videos = $meteor.collection(Videos).subscribe('videos');

  }
]);

/client/views/submit/submit.ng.html

<form>
  <label>URL</label>
  <input ng-model="newVideo.linkurl">
  <label>Description</label>
  <input ng-model="newVideo.description">   
  <button ng-click="videos.save(newVideo); newVideo='';">Add</button>
</form>

<ul>
  <li ng-repeat="video in videos">
    {{video.linkurl}}
    <p>{{video.description}}</p>
  </li>
</ul>  

/model/collections.js Videos = new Mongo.Collection("videos");

/server/publications/videos.js

Meteor.startup(function () {
  if (Videos.find().count() === 0) {
    var videos = [
      { 'linkurl': 'https://www.youtube.com/watch?v=O7zewtuUM_0',
        'description': '1st video'},
      { 'linkurl': 'https://www.youtube.com/watch?v=KSzuiqVjJg4',
        'description': '2nd video'},
    ];
    for (var i = 0; i < videos.length; i++)
      Videos.insert(videos[i]);
  };
});

Meteor.publish("videos", function () {
  return Videos.find();
});

我觉得在这里真正相关的唯一其他文件是/client/app.routes.js,但它很长,而且我在其中几乎没有改变(基本上从关于页面到提交页面)。我也没有包括负责删除项目的控制器或视图,因为它似乎是多余的。

就我有限的知识而言,一切似乎都应该正常工作。因此,我觉得解决方案可能正盯着我看。您对解决此问题的后续步骤有什么建议吗?

4

1 回答 1

5

新条目会在一瞬间添加到列表中,然后消失。

这是由延迟补偿引起的。基本上,客户端数据库在服务器之前处理它,以使操作更快地发生。这是一个非常有用的功能,但如果您不完全掌握它的工作原理,可能很难调试。

我假设您已insecure删除软件包?要测试这是否是问题所在,请运行meteor add insecure并查看您的应用程序现在是否正常工作。

如果应用程序仅在insecure安装时运行,我认为您需要做的是allow写入数据库。

Videos.allow({
  insert: function () {
      // condition where user has write access, return true to allow
      if (Meteor.user()) {
          return true;
     }
   },
  update: function () {},
  remove: function () {}
});

我希望它有效!

于 2015-07-21T06:24:41.520 回答