无法导入javascript类。TypeError:“输入错误”;“类”;不是构造函数
我在将类导入另一个模块时遇到了一个非常奇怪的问题。在我的start.js文件中,我可以导入worker模块,它可以很好地运行脚本。但是,当它到达套接字模块并尝试导入工作模块时,我得到以下错误 当我在socket.js构造函数中记录worker时,它显示为空对象。当我将它记录在start.js中时,它显示为一个函数 我知道这一定是我忽略的非常简单的事情,但我就是看不到无法导入javascript类。TypeError:“输入错误”;“类”;不是构造函数,javascript,node.js,es6-class,Javascript,Node.js,Es6 Class,我在将类导入另一个模块时遇到了一个非常奇怪的问题。在我的start.js文件中,我可以导入worker模块,它可以很好地运行脚本。但是,当它到达套接字模块并尝试导入工作模块时,我得到以下错误 当我在socket.js构造函数中记录worker时,它显示为空对象。当我将它记录在start.js中时,它显示为一个函数 我知道这一定是我忽略的非常简单的事情,但我就是看不到 this.Worker = new worker() ^ TypeError: worker is no
this.Worker = new worker()
^
TypeError: worker is not a constructor
at new Socket (C:\Users\***\Desktop\***\src\modules\socket.js:7:17)
at new Worker (C:\Users\***\Desktop\***\src\modules\worker.js:6:17)
at Object.<anonymous> (C:\Users\***\Desktop\***\start.js:2:16)
at Module._compile (module.js:652:30)
at Object.Module._extensions..js (module.js:663:10)
at Module.load (module.js:565:32)
at tryModuleLoad (module.js:505:12)
at Function.Module._load (module.js:497:3)
at Function.Module.runMain (module.js:693:10)
at startup (bootstrap_node.js:188:16)
worker模块(worker.js)导入我的套接字服务器模块并连接到套接字服务器
const socket = require('./socket')
class Worker {
constructor() {
this.Socket = new socket()
}
async start() {
try {
console.log('ran start')
// Connect to socket server
await this.Socket.connect()
} catch(err) {
console.log('Unable to connect to socket server.', err)
}
}
startJob(work) {
const jobType = work.work.jobType
const jobData = work.work.jobData
// run module based on jobType
}
}
module.exports = Worker
我的套接字服务器模块(socket.js)也会导入(worker.js),这样我就可以在socket.on('process')事件中作为worker.startJob()使用startJob函数
触发错误是因为您没有
工作者
类您有工作者
类(区分大小写)。触发错误是因为您没有工作者
类您有工作者
类(区分大小写).使用模块和导出/导入时,有几件事需要注意
module.exports
对象由module
系统创建
因此,当您这样做时,module.exports=Worker
,Worker
被添加到模块中。export
对象意味着它是对象中的键
当您需要代码中的:
const worker = require('./src/modules/worker')
// class Worker is available as a member
const Worker = new worker.Worker()
如果你不想这样,还有两种方法可以做到:
// note the curly braces and capitalized W because JavaScript is case sensitive
const { Worker } = require('./src/modules/worker');
或者您可以用类替换模块。通过以下方式导出:
module.exports = class {
constructor() {
this.Socket = new socket()
}
async start() {
try {
console.log('ran start')
// Connect to socket server
await this.Socket.connect()
} catch(err) {
console.log('Unable to connect to socket server.', err)
}
}
startJob(work) {
const jobType = work.work.jobType
const jobData = work.work.jobData
// run module based on jobType
}
}
导入方式如下:(注意,您可以将其命名为任何其他名称)
使用模块和导出/导入时,有几件事需要注意
module.exports
对象由module
系统创建
因此,当您这样做时,module.exports=Worker
,Worker
被添加到模块中。export
对象意味着它是对象中的键
当您需要代码中的:
const worker = require('./src/modules/worker')
// class Worker is available as a member
const Worker = new worker.Worker()
如果你不想这样,还有两种方法可以做到:
// note the curly braces and capitalized W because JavaScript is case sensitive
const { Worker } = require('./src/modules/worker');
或者您可以用类替换模块。通过以下方式导出:
module.exports = class {
constructor() {
this.Socket = new socket()
}
async start() {
try {
console.log('ran start')
// Connect to socket server
await this.Socket.connect()
} catch(err) {
console.log('Unable to connect to socket server.', err)
}
}
startJob(work) {
const jobType = work.work.jobType
const jobData = work.work.jobData
// run module based on jobType
}
}
导入方式如下:(注意,您可以将其命名为任何其他名称)
我将它作为const-worker导入并设置为。worker=new-worker()。就像我在start.js中做的那样。const-worker=require(“…”),this.worker=new-worker()我将它作为const-worker导入并设置为this.worker=new-worker()。就像我在start.js中做的那样。const worker=require(“…”),this.worker=new worker()正是我想要的,谢谢你的详细回复!正是我想要的,谢谢你的详细回复!