typescriptecmascript-6typescript1.7

How to import CommonJS module that uses module.exports= in Typescript


The following produces valid, working ES5 but emits the error below. I'm using Typescript 1.7.5 and I think I've read the whole language spec and I cannot figure out why this error is produced.

error TS2349: Cannot invoke an expression whose type lacks a call signature.

a.js (ES5 ambient module with default export)

function myfunc() {
  return "hello";
}
module.exports = myfunc;

a.d.ts

declare module "test" {
    export default function (): string;
}

b.ts

import test = require("test");
const app = test();

b.js (generated ES5):

var test = require("test");
var app = test()

Solution

  • module.exports exports a literal value in a CommonJS module, but export default says you are exporting a default property, which is not what your JavaScript code actually does.

    The correct export syntax in this case is simply export = myfunc:

    declare module "test" {
        function myfunc(): string;
        export = myfunc;
    }