不能在JavaScript中使用我自己的TypeScript库



我一直在为一个看似简单的任务而绞尽脑汁。如果你能给我一些建议,我将不胜感激。

我正在用TypeScript写一个私有库,用于我们公司的TypeScript和JavaScript项目。

库工作得很好,但我似乎无法在JavaScript中导入它。

TS

package.json

{
"name": "rr-comm-bus-js",
"version": "0.3.0",
"description": "",
"main": "lib/src/index.js",
"types": "lib/src/index.d.ts",
"scripts": {
"dev": "ts-node-dev --respawn src/dev/dev.ts",
"build": "rm -rf lib && tsc"
},
"keywords": [],
"dependencies": {
"redis": "^3.1.2"
},
"devDependencies": {
"@types/node": "^16.4.12",
"@types/redis": "^2.8.31",
"nodemon": "^2.0.12",
"ts-node-dev": "^1.1.8",
"typescript": "^4.3.5"
}
}

tsconfig.json

{
"compilerOptions": {
"module": "commonjs",
"esModuleInterop": true,
"target": "es6",
"moduleResolution": "node",
"sourceMap": true,
"outDir": "lib",
"declaration": true,
"noImplicitAny": true,
"declarationMap": true,
"allowJs": true
},
"lib": ["es2015"]
}

JavaScript (Node.js,我想在这里使用这个库)

简化代码…

const MyModule = require("my-module-name");
const myModule = new MyModule(); <--- this line is where the error happens

所以我得到的错误是:

const myModule = new MyModule();
^
TypeError: MyModule is not a constructor

这表明MyModule甚至不是一个类,但它是。我在TS库中获得了类型的智能感知,但我不能使用类。

下面是TS转换成JS的代码:

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const declarations_1 = require("./declarations");
class Communicator {
constructor() {
// constructor logic
};
// more methods...
}
exports.default = MyModule;

我试着遵循多篇文章和指南,改变了tsconfig。Json,并添加了"type" "module"包。

请指教。

试试这个

const MyModule = require("my-module-name").default;
const myModule = new MyModule();

相关内容

最新更新