I\'m writing a \"class\" in node
// mymodule/index.js
function MyClass() {}
MyClass.prototype.method1 = function() {..}
usually I do
Both ways are correct, but try to import in es6 like this without the brackets:
import MyClass from 'mymodule'
Otherwise you would have to export your function like this:
module.exports.MyClass = MyClass
and than import it like this:
import { MyClass } from 'mymodule'
As far as writing an export that is compatible for both ES5 and ES6, Babel already takes care of that for you. (As communicated in the comments to your question. I'm only clarifying for those who got lost in the dialog.)
module.exports = MyClass
will work with both var MyClass = require('mymodule')
and import MyClass from 'mymodule
However, to be clear, the actual syntax you asked about:
import {MyClass} from 'mymodule'
means something different from
import MyClass from 'mymodule'
For the latter, you would have to export it as: module.exports.MyClass = MyClass
, and for ES5 modules it would have to required as var MyClass = require('mymodule').MyClass
From the comments, I understand you are trying to run your ES6 frontend code in some mocha unit tests in node. Yes, you can't do that until node support ES6 modules. If I were you, I would use systemjs to load code for those mocha tests. Mocha supports promises, so it should be fairly painless to load any files before tests.
Writing syntax for both will just create more problems for you.