Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

ES6 classes, with parent in different file, and node.js?

What is the right way to use a class defined in one file and extend it another, in node.js?

Currently I have:

'use strict'

class BasePageHandler {

    constructor(app, settings, context) {

    }
}

return module.exports;

In the 'child' class file I have:

'use strict'

var BasePageHandler = require ('./../BasePageHandler.js');

class FrontpagePageHandler extends BasePageHandler {
    constructor(app, settings, context) {
         super(app, settings, context);
         this.settings = settings;
         this.context = context;
    }
}

This fails with the following error:

TypeError: Class extends value #<Object> is not a function or null

Note, if I have the BasePageHandler in the same file then it works, so it is really when the class is in another file I have an issue.

Currently using node 4.4.0.

like image 831
Andre M Avatar asked Mar 30 '16 21:03

Andre M


2 Answers

You need to correctly export your class inBasePageHandler.js file:

module.exports = BasePageHandler;
like image 118
madox2 Avatar answered Nov 05 '22 23:11

madox2


The accepted answer is technically fine, but really if you're using ES6 then you should go all in and use ES6 export/import.

/*jshint esversion: 6 */

class BasePageHandler {
    constructor(app, settings, context) {
    }
}

export default BasePageHandler;

and then:

/*jshint esversion: 6 */

import BasePageHandler from './../BasePageHandler.js';

class FrontpagePageHandler extends BasePageHandler {
    constructor(app, settings, context) {
         super(app, settings, context);
         this.settings = settings;
         this.context = context;
    }
}
like image 29
jonlink Avatar answered Nov 05 '22 23:11

jonlink