nó v8.9.1
const path = require('path');
import typescript from 'rollup-plugin-typescript2';
import alias from 'rollup-plugin-alias';
export default {
input: './src/index.ts',
output: {
file: 'build.js',
format: 'umd',
name: 'build',
},
plugins: [
typescript( ),
alias( {
core: path.resolve( __dirname, './src/core' ),
} ),
],
};
{
"compilerOptions": {
"target": "es2015"
}
}
{
"name": "rollup-demo",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"build": "rollup -c ./rollup.config.js"
},
"author": "",
"license": "ISC",
"devDependencies": {
"rollup": "^0.56.5",
"rollup-plugin-alias": "^1.4.0",
"rollup-plugin-typescript2": "^0.12.0",
"typescript": "^2.7.2"
}
}
// ./src/index.ts
import A from 'core/a';
export { A };
// ./src/core/a.ts
export default function () {
const x = 12;
console.log( x );
};
rollup-demo/src/index.ts(1,15): semantic error TS2307 Cannot find module 'core/a'.
Se usar rollup-plugin-alias
sozinho, funcionará.
mas com rollup-plugin-typescript2
usados juntos, ele não consegue encontrar o módulo
Você tentou colocar alias() na frente de typescript()?
Você pode contornar isso usando baseUrl
em tsconfig?
Veja mais informações aqui:
https://decembersoft.com/posts/say-goodbye-to-relative-paths-in-typescript-imports/
Coisa de ordem de plugin provável
Eu tentei essa configuração. Definir alias na frente de typescript2 não ajudou =(
Eu encontrei o mesmo problema ao usar @rollup/plugin-alias
e @rollup/plugin-typescript
.
Mover alias
bebind typescript
resolve o problema.
Comentários muito úteis
Eu tentei essa configuração. Definir alias na frente de typescript2 não ajudou =(