Как настроить TypeScript + Babel + Webpack?
у меня есть эти зависимости:
"devDependencies": {
"@types/node": "^4.0.27-alpha",
"babel-core": "^6.10.4",
"babel-loader": "^6.2.4",
"babel-polyfill": "^6.9.1",
"babel-preset-es2015": "^6.9.0",
"babel-preset-stage-0": "^6.5.0",
"ts-loader": "^0.8.2",
"typescript": "^2.0.0",
"webpack": "^1.13.1"
}
.babelrc
{
"presets": [
"es2015",
"stage-0"
]
}
tsconfig.в JSON
{
"compilerOptions": {
"module": "commonjs",
"target": "es6",
"noImplicitAny": false,
"sourceMap": false,
"outDir": "built"
},
"exclude": [
"node_modules"
]
}
webpack.конфиг.js
module.exports = {
entry: ['babel-polyfill', './src/'],
output: {
path: __dirname,
filename: './built/bundle.js',
},
resolve: {
modulesDirectories: ['node_modules'],
extensions: ['', '.js', '.ts'],
},
module: {
loaders: [{
test: /.tsx?$/, loaders: ['ts-loader', 'babel-loader'], exclude: /node_modules/
}],
}
};
/ src / index.ТС
async function foo() {
const value = await bar();
console.log(value);
}
function bar() {
return new Promise((resolve, reject) => {
return resolve(4);
});
}
(async function run() {
await foo();
}());
С этой настройкой он работает, я могу построить и запустить его (журналы 4 Правильно). Однако я всегда получаю некоторые ошибки на webpack:
ERROR in ./src/index.ts
(4,32): error TS2304: Cannot find name 'regeneratorRuntime'.
ERROR in ./src/index.ts
(6,12): error TS2304: Cannot find name 'regeneratorRuntime'.
ERROR in ./src/index.ts
(31,451): error TS2346: Supplied parameters do not match any signature of call target.
ERROR in ./src/index.ts
(40,33): error TS2304: Cannot find name 'regeneratorRuntime'.
ERROR in ./src/index.ts
(41,12): error TS2304: Cannot find name 'regeneratorRuntime'.
кажется, это имеет какое-то отношение к babel-polyfill
.
что я упустил?
3 ответов
(4,32): ошибка TS2304: не удается найти имя "regeneratorRuntime".
это симптом, что выход babel
получает кормили ts
. Это приказ неправильно
исправить
используйте настройку, как описано здесь : http://blog.johnnyreilly.com/2015/12/es6-typescript-babel-react-flux-karma.html
погрузчики всегда выполняются справа налево, поэтому меняется на
test: /\.tsx?$/, loaders: ['babel-loader', 'ts-loader'], exclude: /node_modules/
Исправлена ошибка, так как он будет работать ts-loader
первый.
полный webpack.конфиг.файл JS
module.exports = {
entry: ['babel-polyfill', './src/'],
output: {
path: __dirname,
filename: './dist/index.js',
},
resolve: {
extensions: ['', '.js', '.ts'],
},
module: {
loaders: [{
test: /\.ts$/, loaders: ['babel-loader', 'ts-loader'], exclude: /node_modules/
}],
}
};
пример проекта brunolm / typescript-babel-webpack
Babel 7 не нуждается в TS-загрузчике.
как Бабеля 7 в ts-loader
не нужно, потому что Вавилон 7 понимает TypeScript. Полная информация о a TypeScript + Babel7 + настройка Webpack здесь.
обзор настройки без TS-loader.
установите поддержку TypeScript Babel. Только @babel/preset-typescript
является обязательным; остальные три добавляют дополнительные функции, которые поддерживает TypeScript.
npm install --save-dev @babel/preset-typescript
npm install --save-dev @babel/preset-env
npm install --save-dev @babel/plugin-proposal-class-properties
npm install --save-dev @babel/plugin-proposal-object-rest-spread
настройки дополнительные .babelrc
плагины и пресеты.
{
"presets": [
"@babel/env",
"@babel/preset-typescript"
],
"plugins": [
"@babel/proposal-class-properties",
"@babel/proposal-object-rest-spread"
]
}
и обновить ваш webpack.config.js
(остальной код опущен для ясности).
module: {
rules: [
{
test: /\.(js|jsx|tsx|ts)$/,
exclude: /node_modules/,
loader: 'babel-loader'
}
]
},
resolve: {
extensions: ['*', '.js', '.jsx', '.tsx', '.ts'],
},