- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
每次当我尝试扩展抽象类 Command
并尝试编译时,我都会收到错误:Error: Cannot find module 'src/classes/commandBase'
我的项目有以下结构:
├────tsconfig.json
└────src
├───classes
│ └───commandBase.ts
├───commands
│ └───ping.ts
├───handlers
├───listeners
└───models
命令库.ts
abstract class Command {
name: string;
abstract execute(client: Client, message: Message, args: string[]): void;
constructor(name: string) {
this.name = name;
}
}
export default Command;
平.ts
import Command from "src/classes/commandBase";
class Ping extends Command {
constructor() {
super("ping");
}
async execute(
client: Client,
message: Message,
args: string[]
): Promise<void> {
// ...
}
}
export default Ping;
tsconfig.json
{
"compilerOptions": {
"target": "ESNext",
"module": "CommonJS",
"rootDir": "./src/",
"outDir": "./dist/",
"strict": true,
"moduleResolution": "node",
"importHelpers": true,
"experimentalDecorators": true,
"esModuleInterop": true,
"skipLibCheck": true,
"allowSyntheticDefaultImports": true,
"resolveJsonModule": true,
"forceConsistentCasingInFileNames": true,
"removeComments": true,
"typeRoots": ["node_modules/@types"],
"sourceMap": true,
"baseUrl": ".",
"paths": {}
},
"include": ["./**/**/*.ts"],
"exclude": ["node_modules", "dist"]
}
如果我将 import Command from "src/classes/commandBase";
更改为 import Command from "../classes/commandBase";
一切都有效很好,没有错误出现。问题是我使用自动完成(VS 代码),每次我导入“命令”时,它都会自动写入 "src/classes/commandBase";
另一件事是,如果我创建一个不扩展 Command 但导入它的新文件,一切也都按预期工作。所以我对这种行为很困惑。
文件 foo.ts
import Command from "src/classes/commandBase";
const foo: Command = {
name: "",
execute: function (client: Client, message: Message, args: string[]): void {
throw new Error("Function not implemented.");
}
}
最佳答案
那是因为你的Classes和Commands文件夹在src目录下,你不需要离开那个目录。如果您从主文件夹运行,您的路径应该类似于 ./classes/或 ./commands/Ping。
Here is not specified "./" before source folder
../表示你要离开当前目录上一级 ./在当前目录中
在您的设置中添加 JSON "typescript.preferences.importModuleSpecifier": "relative",
我运行此配置,检查结构和配置是否在 tsconfig.json 中使用 about 模块,并选择“绝对路径”来避免相对路径情况,如“../../../”
import Command from "@classes/commandBase";
tsconfig.json
/* Modules */
"module": "commonjs",
"rootDir": "./src",
"baseUrl": ".",
"paths": { /* Set absolute paths with '@path' */
"@config/*": ["./src/config/*"],
"@controllers/*": ["./src/controllers/*"],
"@services/*": ["./src/services/*"],
"@classes/*": ["./src/classes/*"],
"@commands/*": ["./src/commands/*"],
"@routes/*": ["./src/routes/*"],
"@pages/*": ["./src/pages/*"],
"@utils/*": ["./src/utils/*"],
"@middlewares/*": ["./src/middlewares/*"]
}
// Allow multiple folders to be treated when resolving modules
"typeRoots": [
"./node_modules/@types",
"./src/@types"
package.json
"plugins": [
[
"module-resolver",
{
"alias": {
"@config": "./src/config",
"@controllers": "./src/controllers",
"@services": "./src/services",
"@classes": "./src/classes",
"@commands": "./src/commands",
"@routes": "./src/routes",
"@pages": "./src/pages",
"@utils": "./src/utils",
"@middlewares": "./src/middlewares"
}
}
]
]
}
}
关于typescript - "Module not found"扩展类时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/74154209/
我有 4 个文件。 C:\perlCode2\start.pl6 C:\perlCode2\file0.pm6 C:\perlCode2\folder1\file1.pm6 C:\perlCode2\
我有一个结构如下的模块: /module __init__.py /submod_1 __init__.py submod_1_class.py
我的源代码在 java 7 上编译并在 java 11 上运行。 我正在尝试将 imperva RASP 作为 java 代理集成到 tomcat 中。但是,当我启动 tomcat 服务器时,它抛出以
justExport.js const first = () => { console.log('frist from justExport') } const second = () => {
以下模块用JS文件编写: module.exports = { propA: 1, propB: 2 } 允许稍后从模块导入属性,如:从“路径/到/模块”导入 { propA} 然而,将文件格
我一直在尝试在嵌套的惰性加载模块中实现ngx翻译,但一直未能如愿。我面临的唯一问题是,每当我通过选择器更改语言时,嵌套延迟加载模块中的语言都不会更改。 HttpLoader 工作正常,其他一切工作正常
我没有可重复的示例,因为问题更多是关于模块如何工作。我试图了解如何将一些 react 功能从一个模块传递到下一个模块。过去我收到过有关使用 ObserveEvent 的回复,但是当我在一个模块中使用响
我正在阅读Wikipedia's definition of Dependency inversion principle ,它使用了两个术语高级模块和低级模块,我无法弄清楚。 它们是什么以及依赖倒置
问题 我遇到的一个问题是将两个模块的类型和值带入一个新的组合模块中。我举个例子。目前我有以下两种类型签名 module type Ordered = sig type t (* the type
我是 JavaScript 的新手,最近一直在努力处理导入问题。有一件事我无法理解。 在较旧的节点模块(主要是那些在 ES6 之前出现的模块)中,可以使用 npm 安装,例如 express,通常没有
我正在尝试使用 System.JS 将 material-ui 导入我的 React 应用 在我的应用中,我这样做: import {AppBar, Tabs, Tab, Card, CardTitl
我想使用功能module->exports查找模块提供的所有导出。不幸的是,传递给该函数的模块必须在当前命名空间中声明,然后才能在其上使用该函数。当我静态地知道模块是什么时,这没问题,我只需要将其引入
目录结构如下 outdir |--lib |--- __init__.py |--- abc.py |--indir
这与提到的非常相似 here但是评论或回答中提供的每个解决方案都没有解决我的问题。想看看是否还有其他我应该看的东西。我尝试了不同的路径,比如 ./app/mycomponent/mycomponent
我有两个 Angular 模块:main 和 feature: 主/根模块: @NgModule({ imports: [ StoreModule.forRoot({route
我尝试在 Ubuntu 04.12 LTS x64 中安装“Userful MultiSeat-X64-5.0.1 ...”,在安装结束时遇到以下错误: File "", line 6, in Im
我正在尝试优化我的 vendor bundle.js,因为它已经膨胀并且我正在使用 material-ui 库。 import Card from 'material-ui'; // Very bad
错误: Import-Module : The specified module 'msonline' was not loaded because no valid module file was
我在 Server 2008 SP2(64 位)上执行导入模块 ActiveDirectory 时遇到问题。 NET Framework 3.5 SP1 已安装 我下载了 Windows6.0-KB9
嗯,你好! 我正在编写一个脚本来获取 Sql 作业历史记录,并且需要使用“SqlServer”模块。它已安装,但由于上面的错误消息,我无法导入它。当我到达模块路径时,文件夹“SqlServer”存在并
我是一名优秀的程序员,十分优秀!