7

谁能告诉我为什么下面的代码会引发以下错误?:

Error: A method named '/players/insert' is already defined 

我是 Meteor 和 coffeescript 的新手,所以我可能会忽略一些简单的东西。

这是我将排行榜示例移植到咖啡脚本的端口:

###
Set up a collection to contain player information. On the server,
it is backed by a MongoDB collection named "players."
###
Players = new Meteor.Collection("players")

if Meteor.is_client
  Template.leaderboard.players = ->
    Players.find({}, {sort: {score: -1, name: 1}})

  Template.leaderboard.selected_name = ->
    player = Players.findOne(Session.get "selected_player")
    player and player.name

  Template.player.selected = -> if Session.equals("selected_player", this._id) then "selected" else ''

  Template.leaderboard.events = {
    'click input.inc': ->
      Players.update(Session.get("selected_player"), {$inc: {score: 5}})
  }

  Template.player.events = {
    'click': ->
      Session.set("selected_player", this._id)
  }

# On server startup, create some players if the database is empty.
if Meteor.is_server
  Meteor.startup ->
    if Players.find().count() is 0
      names = [
                "Ada Lovelace"
                "Grace Hopper"
                "Marie Curie"
                "Carl Friedrich Gauss"
                "Nikola Tesla"
                "Claude Shannon"
              ]
      Players.insert({name: name, score: Math.floor(Math.random()*10)*5}) for name in names

完整的堆栈跟踪如下:

[[[[[ ~/dev/meteor/leaderboard ]]]]]

Running on: http://localhost:3000/

node.js:201
        throw e; // process.nextTick error, or 'error' event on first tick
              ^
Error: A method named '/players/insert' is already defined
    at app/packages/livedata/livedata_server.js:744:15
    at Function.<anonymous> (app/packages/underscore/underscore.js:84:24)
    at [object Object].methods (app/packages/livedata/livedata_server.js:742:7)
    at new <anonymous> (app/packages/mongo-livedata/collection.js:111:13)
    at app/leaderboard.js:4:11
    at /Users/alex/dev/meteor/leaderboard/.meteor/local/build/server/server.js:109:21
    at Array.forEach (native)
    at Function.<anonymous> (/Users/alex/dev/meteor/leaderboard/.meteor/local/build/server/underscore.js:76:11)
    at /Users/alex/dev/meteor/leaderboard/.meteor/local/build/server/server.js:95:7
Exited with code: 1

我正在运行 Meteor 版本 0.4.0 (8f4045c1b9)

提前感谢您的帮助!

4

3 回答 3

12

如果您复制文件,无论使用咖啡脚本还是纯 javascript,您也会收到此错误。例如,将源文件复制到名为 Backup 的子目录会产生此错误,因为 Meteor 会合并子目录中的文件。

于 2012-10-23T16:43:42.140 回答
0

这似乎是 coffeelint 的配置问题(使用 npm 全局安装)。

我最初安装了 coffeelint 来检查我的咖啡脚本代码是否正确并且没有错误。

我按照说明安装了 coffeelint:

sudo npm install -g coffeelint

对 .coffee 文件单独运行时,coffeelint 运行良好。

但是,当运行任何添加了 coffeescript 包的 Meteor 项目时,我得到了上述错误。

一时兴起,我认为该错误可能是由于与我现有的节点安装冲突。

我决定先卸载 coffeelint:

sudo npm uninstall -g coffeelint

然后删除了之前meteor生成的leaderboard.js文件。

重新启动流星后,上面的咖啡脚本示例按预期工作,没有错误。

于 2012-09-21T14:45:49.000 回答
0

尝试移动(即复制和删除原件)

Players = new Meteor.Collection("players")

下一次 if Meteor.is_client ,下一次if Meteor.is_server

我不知道确切原因,因为我也是 Meteor 的新手,但这对我有用,我认为服务器端需要它自己的引用以及客户端,尽管在范围之外声明应该做同样的事情(也许是一个错误,请记住它们仍处于 0.5.0 预览版,这让我认为您可能想要升级并尝试一些新版本的新智能包,看起来您使用的是 0.4),但是当文件在我的服务器中无法识别任何东西我定义了流星的根目录(它将这些文件推送到客户端和服务器),我定义了服务器自己的引用,我得到了同样的错误,直到我移动了“公共”声明参考给服务器和客户端各自的副本,没有任何效果。

希望这会有所帮助...

于 2012-10-20T16:10:11.310 回答