尝试按照官方手册实现一个模块,我得到这个错误消息:
Uncaught ReferenceError:未定义exports
在app.js: 2
但在我的代码中,我从未使用过名称exports。
我该如何解决这个问题?
文件
app.ts
let a = 2;
let b:number = 3;
import Person = require ('./mods/module-1');
模块- 1. t
export class Person {
constructor(){
console.log('Person Class');
}
}
export default Person;
tsconfig.json
{
"compilerOptions": {
"module": "commonjs",
"target": "es5",
"noImplicitAny": false,
"sourceMap": true,
"outDir": "scripts/"
},
"exclude": [
"node_modules"
]
}
编辑:
这个答案可能不起作用,这取决于您是否不再针对es5,我将尝试使答案更完整。
原来的答案
如果CommonJS没有安装(它定义了exports),你必须从tsconfig.json中删除这一行:
"module": "commonjs",
根据注释,仅这一点可能不适用于tsc的后续版本。如果是这样的话,你可以安装一个模块加载器,比如CommonJS, SystemJS或RequireJS,然后指定它。
注意:
看看tsc生成的main.js文件。你会发现在最上面:
Object.defineProperty(exports, "__esModule", { value: true });
它是错误信息的根,删除"module": "commonjs",,它将消失。
我有同样的问题,并解决了它添加“es5”库tsconfig。Json是这样的:
{
"compilerOptions": {
"target": "es5", //defines what sort of code ts generates, es5 because it's what most browsers currently UNDERSTANDS.
"module": "commonjs",
"moduleResolution": "node",
"sourceMap": true,
"emitDecoratorMetadata": true, //for angular to be able to use metadata we specify in our components.
"experimentalDecorators": true, //angular needs decorators like @Component, @Injectable, etc.
"removeComments": false,
"noImplicitAny": false,
"lib": [
"es2016",
"dom",
"es5"
]
}
}
我也犯了同样的错误。在我的例子中,这是因为我们在我们的TypeScript AngularJS项目中有一个老式的import语句,像这样:
import { IAttributes, IScope } from "angular";
它被编译成这样的JavaScript:
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
这在以前是需要的,因为我们在代码中使用了IAttributes,否则TypeScript不知道该用它做什么。
但是在删除import语句并将IAttributes转换为ng之后。IAttributes这两行JavaScript代码消失了——错误消息也消失了。
试试@iFreilicht上面建议的方法。如果在你安装了webpack之后没有工作,你可能只是从网上的某个地方复制了一个webpack配置,并在那里配置了你想要输出支持CommonJS的错误。确保在webpack.config.js中不是这样:
module.exports = {
mode: process.env.NODE_ENV || "development",
entry: {
index: "./src/js/index.ts"
},
...
...
output: {
libraryTarget: 'commonjs', <==== DELETE THIS LINE
path: path.join(__dirname, 'build'),
filename: "[name].bundle.js"
}
};
注意:这可能不适用于OP的答案,但我得到了这个错误,这就是我解决它的方式。
所以我面临的问题是,当我从一个特定的CDN检索一个'js'库时,我得到了这个错误。
我做的唯一错误的事情是从CDN的cjs目录导入,就像这样:
https://cdn.jsdelivr.net/npm/@popperjs/core@2.4.0/dist/cjs/popper.min.js
注意到dist/cjs部分了吗?这就是问题所在。
在我的例子中,我回到CDN (jsdelivr)并导航到umd文件夹。我可以找到另一组popper.min.js,这是要导入的正确文件:
https://cdn.jsdelivr.net/npm/@popperjs core@2.4.0 / dist / / popper.min.js umd格式。
{
"compileOnSave": false,
"compilerOptions": {
"baseUrl": "./",
"outDir": "./dist",
"sourceMap": true,
"declaration": false,
"module": "esnext",
"moduleResolution": "node",
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"target": "es5",
"typeRoots": ["node_modules/@types"],
"lib": ["es2018", "dom"]
}
}
我遇到了同样的问题,但我的设置需要不同的解决方案。
我使用的是带有config-override .js文件的create-react-app-rewired包。以前,我从customize-cra中使用addBabelPresets导入(在override()方法中),并决定将这些预置抽象到一个单独的文件。巧合的是,这解决了我的问题。
我在config-override .js的override()方法中添加了useBabelRc(),并创建了一个babel.config.js文件,内容如下:
module.exports = {
presets: [
'@babel/preset-react',
'@babel/preset-env'
],
}
我有类似的问题,原来的海报的问题:
我最好告诉你我犯了什么错误以及我是如何改正的,这可能会帮助到别人。
我有javascript nodejs项目,并将其转换为typescript。
之前的包装。我有“类型”:“模块”当我在JavaScript运行。
当我把它转换成TypeScript项目,并开始转换.ts文件中的文件,并使用以下命令开始运行:
npx tsc test.ts && node test.ts
我会得到上面的错误。
我通过简单地从package.json中删除“type”:“module”来摆脱这个错误
我的tsconfig。Json格式如下:
{
"compilerOptions": {
"target": "esnext",
"lib": ["es6", "es5", "es7", "dom"],
"allowJs": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"strict": true,
"forceConsistentCasingInFileNames": true,
"module": "es6",
"outDir": "./build",
"moduleResolution": "node",
"resolveJsonModule": true,
"skipLibCheck": true
},
"exclude": ["node_modules", "build"]
我使用节点14和TypeScript 4.2.4
我认为问题可能是配置不匹配。
下面的工作解决方案1为您提供了ES模块的正确配置。
下面的工作解决方案2为您提供了正确的CommonJS配置。
混合解决方案1+2给你一个错误。
为了清晰起见,我在这里只发布了部分内容。
Github项目https://github.com/jmmvkr/ts-express/
准备一套完整的文件来演示工作解决方案1和解决方案2。
工作方案1,ES模块
/* Configuration for ES Module */
// tsconfig.json
{
"compilerOptions": {
"module": "es6", // or "esnext"
}
}
// package.json
{
"type": "module", // type is module
}
工作解决方案2,CommonJS
/* Configuration for CommonJS */
// tsconfig.json
{
"compilerOptions": {
"module": "commonjs",
}
}
// package.json
{
"type": "", // type is NOT module
}
混合,不工作
/* Mixed, got ReferenceError: exports is not defined in ES module scope */
// tsconfig.json
{
"compilerOptions": {
"module": "commonjs",
}
}
// package.json
{
"type": "module", // type is module
}
首先,在你的公共文件夹中找到你的index.html,找到脚本的引用<script src="myScript.js"></script>,并添加type="module"
像这样:
<script type="module" src="myScript.js"></script>
其次,在您的tsconfig中。Json,确保目标设置为es5,模块设置为es2015
"compilerOptions": {
"target": "es5", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */
/* Modules */
"module": "es2015", /* Specify what module code is generated. */
}
注意:确保使用.js扩展名导入,例如import Piece from './classes/ Piece .js'
所以这是一个超级通用的TypeScript错误,这个StackOverflow问题是我研究我的问题的各种查询的第一个结果。它有38.5万的浏览量。
对于那些使用Angular / TypeScript和Angular库使用ng-packagr时看到通用的“ReferenceError: exports is not defined”的人,你需要定义public-api。每个功能/组件/服务的t,这样你就可以将它包含在索引中。例如在这篇文章的回购中找到的
节点16或18(下周LTS为18)
Angular 2+(目前有14个)
打印稿4.6.4-4.8.2
一些简单的例子类似于引用Creating Libraries
ng new workspace --no-create-application
cd workspace
ng generate app home --routing=true --style=scss
ng generate app admin --routing=true --style=scss
ng generate library lib
... # include your library 'lib' into your application 'home'
ng build lib --watch &
ng serve home --open
没有直接解释的是你的索引。Ts和public-api。Ts文件需要在每个特性/组件/服务中。如果你有一个复杂的库,比如下面回购中的这些示例特性A、B和C。回购有以下几点:
src / lib
一个
索引。Ts(只引用。/public-api)
公共api。Ts(只引用目录中导出的文件)
功能b
索引。Ts(只引用。/public-api)
公共api。Ts(只引用目录中导出的文件)
feature-c
索引。Ts(只引用。/public-api)
公共api。Ts(只引用目录中导出的文件)
我也有这个问题。然后我只是把“module”:“commonjs”改为“module”:“ESNext”,一切都正常工作。
这是tsconfig.json:
{
"compilerOptions": {
"module": "ESNext",
"esModuleInterop": true,
"target": "ESNext",
"moduleResolution": "node",
"sourceMap": true,
"outDir": "dist",
},
"lib": ["ESNext"],
}
希望它能解决你的问题!
我在切换到“Node 16 + ESM + strict”tsconfig.json后不久就遇到了这个错误。
我认为ESM的改变是造成这种情况的原因。
我必须对文件进行等分,以找出根本原因:
exports.webhookTaskProcessor = functions.firestore
.document("items/{itemId}/tasks/{taskId}")
.onCreate((_change, context) => {
processItemTasks(context.params.itemId);
});
这就解决了问题:
export const webhookTaskProcessor = functions.firestore
.document("items/{itemId}/tasks/{taskId}")
.onCreate((_change, context) => {
processItemTasks(context.params.itemId);
});
如果错误信息更有用一点,那就太棒了。我希望这条面包屑对你有用。