我有个后遗症。我阅读了文档并做了和他们一样的事情,但是总是被以下错误所困扰。请帮我解决这个错误。
以下是错误
TypeError:Db.Define不是对象上的函数。(/home/robin/public/server/models/users.js:6:17)
在module._compile(internal/modules/cjs/loader.js:1151:30)
位于object.module._extensions..js(internal/modules/cjs/loader.js:1171:10)
在module.load处(internal/modules/cjs/loader.js:1000:32)
在function.module._load(internal/modules/cjs/loader.js:899:14)
在module.require处(internal/modules/cjs/loader.js:1040:19)
要求(internal/modules/cjs/helpers.js:72:18)
在物体上。(/home/robin/public/server/routes/user.js:4:14)
在module._compile(internal/modules/cjs/loader.js:1151:30)
位于object.module._extensions..js(internal/modules/cjs/loader.js:1171:10)
在module.load处(internal/modules/cjs/loader.js:1000:32)
在function.module._load(internal/modules/cjs/loader.js:899:14)
在module.require处(internal/modules/cjs/loader.js:1040:19)
null
在物体上。(/home/robin/public/server/app.js:10:19)
在module._compile(internal/modules/cjs/loader.js:1151:30)
[nodemon]应用程序崩溃-在启动前等待文件更改。。。
这是代码
模型
const Sequelize = require("sequelizer");
const db = require("../config/database");
const users = db.define("user", {
email: {
type: Sequelize.STRING
}
});
module.exports = users;
null
var fs = require("fs");
var path = require("path");
var Sequelize = require("sequelize");
var basename = path.basename(module.filename);
var env = process.env.NODE_ENV || "development";
var config = require(__dirname + "/../config/config.json")[env];
var db = {};
if (config.use_env_variable) {
var sequelize = new Sequelize(process.env[config.use_env_variable]);
} else {
var sequelize = new Sequelize(
config.database,
config.username,
config.password,
config
);
}
fs.readdirSync(__dirname)
.filter(function(file) {
return (
file.indexOf(".") !== 0 && file !== basename && file.slice(-3) === ".js"
);
})
.forEach(function(file) {
var model = sequelize["import"](path.join(__dirname, file));
db[model.name] = model;
});
Object.keys(db).forEach(function(modelName) {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
sequelize
.authenticate()
.then(() => {
console.log("Connection has been established successfully.");
})
.catch(err => {
console.error("Unable to connect to the database:", err);
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
您的模型
const Sequelize = require("sequelizer");
const db = require("../config/database");
module.exports = (sequelize, Sequelize) => {
const users = db.define("user", {
email: {
type: Sequelize.STRING
}
})
return Users
}
我想,应该是
db.sequelize.define(user),
不是
db.define(user)“,
const Sequelize = require("sequelizer");
const db = require("../config/database");
const users = db.sequelize.define("user", {
email: {
type: Sequelize.STRING
}
});
module.exports = users;
(或)(已更新)
module.exports = (sequelize, Sequelize) => {
const users = sequelize.define("user", {
email: {
type: Sequelize.STRING
}
});
}
不要忘记在Dasebase文件中导入用户模型,例如:
db.sequelize = sequelize;
db.Sequelize = Sequelize;
db.users = require('./path/to/usermodel.js')(sequelize, Sequelize);
module.exports = db;
我也遇到了同样的问题,在做了一些研究之后,发现在使用
null
const fs = require('fs');
const path = require('path');
const Sequelize = require('sequelize');
const basename = path.basename(module.filename);
const env = process.env.NODE_ENV || 'development';
const config = require('../config/config.json')[env];
const db = {};
let sequelize;
if (config.use_env_variable) {
sequelize = new Sequelize(process.env[config.use_env_variable]);
} else {
sequelize = new Sequelize(
config.database, config.username, config.password, config
);
}
fs
.readdirSync(__dirname)
.filter(file =>
(file.indexOf('.') !== 0) &&
(file !== basename) &&
(file.slice(-3) === '.js'))
.forEach(file => {
const model = sequelize.import(path.join(__dirname, file));
db[model.name] = model;
});
Object.keys(db).forEach(modelName => {
if (db[modelName].associate) {
db[modelName].associate(db);
}
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;
希望这有用!
问题内容: 当我试图在React版本15.2.0中使用这两个函数时,我在代码中发现了一个问题,尽管如此,我找到了一种解决方法,但是我想知道是否有更好的解决方案。 因此,每当我尝试运行index.html文件时,都不会显示任何内容,但是控制台会出现第一个错误: React.render不是function 。我发现发生这种情况是因为新版本的React需要使用react-dom,即 现在问题已解决,但
问题内容: 我正在为无法解决的错误而烦恼。我有以下内容; JSON格式 和下面的jQuery 但是我收到一个错误,认为map.data未定义为函数?看着它,我不知道什么是行不通的,因为我已将其从以前使用的代码复制到新项目中。唯一不同的是JSON源。上一个没有[]括号之前的部分。这是什么让我失望吗? 问题答案: 对象,在JavaScript没有方法,它只是为数组,。 因此,为了使您的代码正常工作,请
问题内容: 我有这段代码可用于从Arduino接收数据,但我想将数据发送回Arduino并在客户端页面上获得响应。我添加了侦听功能,但是从客户端页面发送数据时却不断获取信息。 test.js 问题答案: 您的价值不是应有的价值。 通常的做事方式是这样的: 但是我猜你的价值是这样的: 那不是同一回事。那就是模块句柄。但是,当您这样做时: 然后,是一个socket.io实例。您可以将侦听器绑定到实例,
问题内容: 我正在尝试使用来运行任何按钮的功能。我在Firebug中遇到错误 document.getElementByClass不是函数 这是我的代码: 问题答案: 您可能是想(然后从结果节点列表中获取第一项): 您可能仍然会收到错误 不是功能 但是,在较旧的浏览器中,如果需要支持那些较旧的浏览器,则可以提供后备实现。
编辑:阅读问题末尾的部分! 我的服务代码: 在我的组件中,我有这个提交功能: 这里和这里都有类似的错误。答案总是包含rxjs函数,但是我这样做了,所以我不太确定,为什么会出现这个错误。 编辑: 因此,实际的问题不是这个函数,而是主应用程序中我的路线前缺少“/”。js文件。解决了这个问题之后,问题就消失了。
问题内容: 我有以下组件,该组件维护在特定元素上触发事件时更新的状态,并且在更新状态时将其作为道具传递给另一个组件。我目前正在尝试为什么我得到以下错误“ this.setState不是函数”,它很可能没有绑定到正确的上下文。但是我不确定,我这样做正确吗? 编辑: 我只是意识到上下文会在“onreadyStateChange”函数时发生更改,所以我在searchGif中做了以下操作 问题答案: 您正
问题内容: 我将Webpack与firebase和firebase-admin一起使用。 要安装firebase,我跑了 我正在使用导入Firebase, 我也试过 我试过了 根据网络入门指南中的建议 但是,当我尝试使用时,出现错误 console.js:32 TypeError:firebase.auth不是函数 当我使用调试器进行检查时,我发现它实际上没有功能: 如何使用webpack将aut
问题内容: 我正在尝试将数据发布到在mLab上创建的数据库中,但出现此错误,但我不知道出了什么问题。我也阅读了有关此主题的先前询问的问题,但由于无法解决错误我是新来的。因此,我在这里发布了我要实现的代码,该代码取自本教程https://medium.freecodecamp.com/building- a-simple-node-js-api-in-under-30-minutes- a07ea9