最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - ES6 classes, with parent in different file, and node.js? - Stack Overflow

programmeradmin6浏览0评论

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.

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.

Share Improve this question asked Mar 30, 2016 at 21:15 Andre MAndre M 7,5249 gold badges61 silver badges105 bronze badges 1
  • You may want to use ES6 native modules with the Common JS transform plugin for Babel, instead module.exports. That way, your code will stay future-ready for when Node implements modules natively. – Dan Dascalescu Commented Oct 3, 2016 at 1:51
Add a comment  | 

2 Answers 2

Reset to default 39

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

module.exports = BasePageHandler;

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;
    }
}
发布评论

评论列表(0)

  1. 暂无评论