gpt4 book ai didi

node.js - 如何解决未捕获的 ReferenceError : COLLECTION is not defined at :1:1 in Meteor. js/MongoDB

转载 作者:可可西里 更新时间:2023-11-01 09:47:27 28 4
gpt4 key购买 nike

我正在通过 Eduonix.com 学习完整的堆栈类(class)。似乎某些代码语法已被弃用,因为我必须安装多个旧版本才能完成某些部分。当我来到 Meteor.js 部分时,这没有帮助,所以我安装了最新的并进行了一些搜索,使我能够完成第一课。我在第二节课中尝试了同样的方法(当我遇到这个错误时),但是我发现的任何东西都没有运气。

当我尝试使用时出现此错误

todos.find().fetch()

在浏览器的控制台中。

相关文件结构:

client
--main.html
--main.js
lib
--collections.js

View on github

在类(class)课上,行

import { Todos } from '../lib/collections';

不存在于 ma​​in.js 和行中

export const Todos = new Mongo.Collection('todos');

collections.js 中呈现为

Todos = new Mongo.Collection('todos');

我试过改变

import { Todos } from '../lib/collections';

import { Todos } from '/lib/collections';

但它什么也没做。

我也试过只添加

Todos = new Mongo.Collection('todos');

ma​​in.js,但我得到一个错误,说“todos”已经被定义了(只是在我尝试运行控制台命令时得到相同的未定义错误,因为不知何故它是已经定义但仍未定义)。

我在发表这篇文章之前根据在线查找类似问题进行了这些更改,希望它能像添加一样节省我

import './main.html';

ma​​in.js 当我收到与此错误之前的错误相关的类似未定义错误时执行此操作。

ma​​in.html

<head>
<title>QuickTodos</title>
</head>

<body>
{{> main}}
</body>

<Template name="main">
<header>
<h1>{{title}}</h1>
</header>
<ul>
{{#each todos}}
{{> todo}}
{{/each}}
</ul>
</template>

<template name="todo">
<li>{{text}}</li>
</Template>

ma​​in.js

import { Template } from 'meteor/templating';
import './main.html';
import { Todos } from '../lib/collections';

const todos = [
{text:'Pickup kids from school'},
{text:'Go food shopping'},
{text:'Meeting with boss'}
];

Template.main.helpers({
title(){
return 'QuickTodos';
},
todos(){
return todos;
}
});

collections.js

import {Mongo} from 'meteor/mongo';

export const Todos = new Mongo.Collection('todos');

当我运行时

todos.find().fetch()

我希望得到一个空数组,但我得到的是:

VM1905:1 
Uncaught ReferenceError: todos is not defined
at <anonymous>:1:1

我做错了什么?

最佳答案

我注意到的第一件事是这两行的大小写不同,这意味着它们将指向不同的变量(因此未定义 todos):

export const Todos = new Mongo.Collection('todos');
todos.find().fetch()

第二,因为 Meteor 使用 CommonJS 模块,你声明的任何变量都将是该模块的本地变量,并且不会在控制台上可用。
(有一些异常(exception),比如声明时没有使用 varletconstTodos,它们的作用域将跨越整个应用程序,但仍然不是全局的或在控制台中可用)

您可以通过将变量作为属性添加到 window 来强制它成为全局变量:

import { Mongo } from 'meteor/mongo';
export const Todos = new Mongo.Collection('todos');
window.Todos = Todos; // here we make it global

然后只要通过client/main.js导入这个文件,就可以在控制台使用Todos

这对于小型应用和测试内容来说很好,但会增加名称冲突的可能性,并使大型应用更难理解代码的来源。

如果您想以“正确”的方式为模块系统做事,您可以使用 require 在控制台中访问模块的导出:

> Todos = require('/lib/collections').Todos

关于node.js - 如何解决未捕获的 ReferenceError : COLLECTION is not defined at <anonymous>:1:1 in Meteor. js/MongoDB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57778866/

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