I have this sample class sync.js as a module somewhere on my project.
'use strict';
export default class Sync{
constructor(dbConnection){
this.dbConnection = dbConnection;
}
test(){
return "This is a test " + this.dbConnection;
}
}
Then somewhere on my controller I am using this class as :
'use strict';
import Sync from '../../path/to/module'; // <-- works fine
const sync = new Sync('CONNECTION!'); // <-- meh
console.log(sync.test());
I was expecting something like this to be logged on the console This is a test CONNECTION!
. But instead I am getting this error. TypeError: object is not a constructor
What did I do wrong?
By the way if I removed the line const sync = new Sync('CONNECTION!');
and changed console.log()
to console.log(Sync.test());
the output This is a test undefined
is printed which is kind of what I expected. But what's wrong with my instatiation?
WTF?
Edit
Guys I think I found the problem, based on @JLRishe and rem035 pointed out, it was returning the instance of the class not the class itself. In fact there is an index.js
that imports the './sync'
js file and exporting is as export default new Sync();
. Here's the whole index.js
.
'use strict';
import Sync from './sync';
export default new Sync(); // <-- potential prodigal code
The module tree looks like this.
module
|
|_ lib
| |_ index.js // this is the index.js I am talking about
| |_ sync.js
|
|_ index.js // the entry point, contains just `module.exports = require('./lib');`
Now. How do I export export default new Sync();
without doing new
?
EDIT 2
Just remove the
new
keyword frommodule/lib/index.js
:Or directly import from
module/lib/sync.js
EDIT 1
Based on the what you are saying is logged,
it seems like your import is returning an instance of the class (which is an object), rather than the class definition itself.
So
console.log(new Sync())
would return what you are saying,not
console.log(Sync)
Are you sure you aren't calling
new Sync
anywhere prior to exporting?Initial answer
The code in question works fine:
Based on your error:
Your
import
is not returning what you think it's returning and you are trying tonew
something that cannot be instantiated.Most likely your
import
path is wrong.Since this is the top result on google:
If you are using
require()
statements in Node to import classes and introduce a circular dependency, you will suddenly see this error popping up becauserequire()
is returning{}
instead of the class.