- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
看起来很微不足道的问题。我有一个使用 rollup-plugin-typescript 和 rollup-plugin-dts 的汇总 typescript 配置。我想将我所有的 d.ts 文件捆绑到一个 d.ts 文件中,而不是让它镜像我的项目结构。我遵循了一些教程,最终得到了下面的配置。
问题: dts() 正确捆绑文件,但保留原始构建结构。我的资源都没有解决这个问题。不应该删除现在过时的输入文件吗?我处理插件不好吗?
我从哪里开始:
dist/
├── index.js
├─ dts //I compile my types into here, below is my mirrored project structure
├── components
│ ├── Button.d.ts
│ ├── index.d.ts
├── index.d.ts
我想要的是:
dist/
├── index.js
├── index.d.ts //everything bundled here
不幸的是我得到了什么:
dist/
├── index.js
├─ dts //All of this is still here, it shouldn't be
├── components
│ ├── Button.d.ts
│ ├── index.d.ts
├── index.d.ts
├── index.d.ts //It bundled correctly to this additional file though
配置文件
{
"compilerOptions": {
"allowJs": true,
"allowSyntheticDefaultImports": true,
"declaration": true,
"declarationDir": "dts",
"downlevelIteration": true,
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
"isolatedModules": true,
"jsx": "react-jsx",
"lib": ["dom", "dom.iterable", "esnext"],
"module": "esnext",
"moduleResolution": "node",
"noEmit": true,
"noFallthroughCasesInSwitch": true,
"noImplicitAny": true,
"resolveJsonModule": true,
"skipLibCheck": true,
"sourceMap": true,
"strict": true,
"target": "es5",
"strictFunctionTypes": true
},
"include": ["src/"],
"exclude": ["node_modules", "build", "dist", "src/stories/**", "**/*.stories.ts", "**/*.test.ts", "**/*.test.tsx"]
}
汇总配置文件
import babel from 'rollup-plugin-babel';
import resolve from '@rollup/plugin-node-resolve';
import external from 'rollup-plugin-peer-deps-external';
import { terser } from 'rollup-plugin-terser';
import commonjs from '@rollup/plugin-commonjs';
import dts from 'rollup-plugin-dts';
import typescript from '@rollup/plugin-typescript';
export default [
{
input: './src/index.ts',
output: [
{
file: 'dist/index.js',
format: 'cjs',
},
{
file: 'dist/index.es.js',
format: 'es',
exports: 'named',
},
],
plugins: [
typescript({
tsconfig: './tsconfig.json',
}),
babel({
exclude: 'node_modules/**',
presets: ['@babel/preset-react'],
}),
resolve(),
commonjs(),
external(),
terser(),
],
},
{
input: './dist/dts/index.d.ts',
output: [{ file: 'dist/index.d.ts', format: 'es' }],
plugins: [dts()],
},
];
最佳答案
我最近也遇到了类似的问题,并且能够想出一个漂亮的解决方案,并在配置文件中添加了一些内容。我只是在你的文件中添加东西。对于解决方案,我使用了 rollup-plugin-delete包裹。基本上我们必须删除 dts
构建完成后的文件夹。
import babel from 'rollup-plugin-babel';
import resolve from '@rollup/plugin-node-resolve';
import external from 'rollup-plugin-peer-deps-external';
import { terser } from 'rollup-plugin-terser';
import commonjs from '@rollup/plugin-commonjs';
import dts from 'rollup-plugin-dts';
import typescript from '@rollup/plugin-typescript';
// Added this
import del from "rollup-plugin-delete";
export default [
{
input: './src/index.ts',
output: [
{
file: 'dist/index.js',
format: 'cjs',
},
{
file: 'dist/index.es.js',
format: 'es',
exports: 'named',
},
],
plugins: [
typescript({
tsconfig: './tsconfig.json',
}),
babel({
exclude: 'node_modules/**',
presets: ['@babel/preset-react'],
}),
resolve(),
commonjs(),
external(),
terser(),
],
},
{
input: './dist/dts/index.d.ts',
output: [{ file: 'dist/index.d.ts', format: 'es' }],
plugins: [
dts(),
del({ hook: "buildEnd", targets: "./dist/dts" }), //<------ New Addition
],
},
];
在
tsconfig.json
文件,它提到声明类型文件应该输出到
dts
文件夹。取决于从
index.ts
导出的类型文件,类型将在
dts/index.d.ts
中声明和导出通过 typescript 转译过程。该文件夹可能还有其他文件。使用
rollup-plugin-dts ,它结合了来自
dts/index.d.ts
的所有导出和需要的类型到单个文件定义文件
index.d.ts
在
dist
文件夹。此过程完成后,我们要删除
dts
文件。为此,我们使用
rollup-plugin-delete
插件,让我们可以访问
rollup build hooks .这里我们要删除
dts
构建过程完成后的文件夹;为此,我们使用
buildEnd Hook ,以及目标文件夹名称。这将确保
dts
一旦汇总完成捆绑,文件夹将被删除。
关于typescript - rollup-plugin-dts 留下剩余的 d.ts 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68922574/
目前,我在单击我的正文时打开一个新选项卡,但它将焦点更改为子窗口。但我想通过留下窗口来做到这一点,这样弹出窗口就不会被阻止,并且我可以将焦点放在当前窗口上。 以下代码当前正在运行 /** * For
我有一个带有线性渐变的 css 背景图像。 CSS 代码: .footer-about { display: flex; align-items: center; justif
在服务中包含以下代码(假设在快速端点上): async function (res, req, next) { const fetch = require('node-fetch'); awa
我正在使用 IImageList 和 SHGetFileInfo 为任何给定路径提取巨型图标。一旦我有了它,然后我使用 DrawIconEx 将 HICON 渲染到 HBITMAP 中,最终使用 GD
我有图表并计算了网络密度,现在我应该只保留具有最大权重的分支(网络密度的前 10%,例如 200 中权重最大的 20 个分支)。我找不到该怎么做? 最佳答案 这个问题有点令人困惑,因此,如果稍后出现更
我一直在尝试使用 jquery 创建一种效果,当您将鼠标移到一个 div 上时,整个 body 都会移动,并沿着它经过的点留下一条轨迹。我创建了一个可以使整个 body 移动的功能,但我找不到离开轨迹
我想在桌面上显示放大和缩小图标(控件),而仅在移动设备上浏览时显示 gps 图标。我正在使用这个 css https://unpkg.com/leaflet@1.1.0/dist/leaflet.cs
相关代码(索引为数组大小): typedef struct elemento { unsigned long linha; unsigned long coluna; doub
我有一个 div,因此当我单击时,它会切换为展开或缩回。它在所有浏览器上都运行良好,尽管有一点让我很感兴趣。在谷歌浏览器上,当它缩回时,它会在运动中留下细线。 www.rezoluz.com/logi
每当我的应用程序尝试通过调用 CreateDIBSection() 或使用 LR_CREATEDIBSECTION 标志调用 LoadImage() 来创建 DIB 部分时,它似乎都会成功返回。它返回
我想在 Protractor 测试中脱离 Selenium 控制流。 以下是我迄今为止遇到的步骤和问题: 1。逐个测试禁用它 我的第一个想法是使用 SELENIUM_PROMISE_MANAGER 以
我正在构建一个部署在 CentOS 7.2 上的 ASP.Net Core (netcore 1.1) 应用程序。 我有一个通过 System.Diagnostics.Process 调用外部进程(也
我正在为我的网站创建一个聊天小部件。用户将能够输入纯文本 - 没有 html。 为了消除 HTML 标记并允许用户使用“”,我正在接受他们的输入并在用户屏幕的输入上使用 strip_tags() 和输
我是一名优秀的程序员,十分优秀!