Webpack 和 TypeScript:无法在 node.d.ts 中解析模块 'child_process'
Webpack and TypeScript: Cannot resolve module 'child_process' in node.d.ts
我试图通过 awesome-typescript-loader 让 webpack、typescript 和 react.js 一起工作,但我经常出错。
我在版本 0.3.0-rc.2 和 webpack 1.8.9 上使用了很棒的 typescript 加载器
这是我的 webpack.config.js:
module.exports = {
entry: './ui/index.ts',
output: {
path: __dirname + '/build-ui',
filename: 'app.js',
publicPath: 'http://localhost:8090/assets'
},
module: {
loaders: [
{
test: /\.jsx$/,
loader: 'jsx-loader?insertPragma=React.DOM&harmony'
},
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
{
test: /\.scss$/,
loader: "style-loader!css-loader!sass-loader"
},
{
test: /\.(png|jpg)$/,
loader: 'url-loader?limit=8192'
},
{
test: /\.ts$/,
loader: 'awesome-typescript-loader'
}
]
},
resolve: {
extensions: ['', '.js', '.jsx', '.ts']
}
};
当我 运行 webpack 开发服务器和我的 index.ts 看起来像这样时:
alert('hello');
它指出以下错误:
ERROR in ./ui/index.ts
/Users/..../typings/node/node.d.ts:29:12
Subsequent variable declarations must have the same type. Variable 'require' must be of type 'WebpackRequire', but here has type '{ (id: string): any; resolve(id: string): string; cache: any; extensions: any; main: any; }'.
当我放入参考路径时也是如此。
当我尝试通过 import React = require('react');
导入 React.js 时,它指出:
ERROR in ./ui/index.ts
Module build failed: Cannot resolve module 'child_process' in /..../typings/node
Required in /..../typings/node/node.d.ts
我从 loader 仓库复制了 node.d.ts 文件,还是不行。
有没有人能够让这个组合顺利工作?或者我应该只使用不同的网络打包器吗?
我真的很想让它与 webpack 一起工作。
您可以考虑使用其他 webpack TypeScript loader. I know a few had issues with node stuff. There are also a couple starter kits 可能会有所帮助。
免责声明:我是 ts-loader
.
的维护者
尝试创建一个 tsconfig.json
文件。
例如,当您使用 awesome-typescript-loader
时,这应该有效:
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"sourceMap": true,
"noEmitHelpers": true
},
"exclude": [
"node_modules"
],
"awesomeTypescriptLoaderOptions": {
"forkChecker": true
},
"compileOnSave": false,
"buildOnSave": false,
"atom": { "rewriteTsconfig": false }
}
您只缺少一把钥匙 target: 'node'
。
这可以确保您的目标环境是 Node.js 而不是浏览器,因此会忽略本机依赖项。
最终配置:
module.exports = {
entry: './ui/index.ts',
target: 'node',
output: {
path: __dirname + '/build-ui',
filename: 'app.js',
publicPath: 'http://localhost:8090/assets'
},
module: {
loaders: [
{
test: /\.jsx$/,
loader: 'jsx-loader?insertPragma=React.DOM&harmony'
},
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
{
test: /\.scss$/,
loader: "style-loader!css-loader!sass-loader"
},
{
test: /\.(png|jpg)$/,
loader: 'url-loader?limit=8192'
},
{
test: /\.ts$/,
loader: 'awesome-typescript-loader'
}
]
},
resolve: {
extensions: ['', '.js', '.jsx', '.ts']
}
};
我试图通过 awesome-typescript-loader 让 webpack、typescript 和 react.js 一起工作,但我经常出错。
我在版本 0.3.0-rc.2 和 webpack 1.8.9 上使用了很棒的 typescript 加载器
这是我的 webpack.config.js:
module.exports = {
entry: './ui/index.ts',
output: {
path: __dirname + '/build-ui',
filename: 'app.js',
publicPath: 'http://localhost:8090/assets'
},
module: {
loaders: [
{
test: /\.jsx$/,
loader: 'jsx-loader?insertPragma=React.DOM&harmony'
},
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
{
test: /\.scss$/,
loader: "style-loader!css-loader!sass-loader"
},
{
test: /\.(png|jpg)$/,
loader: 'url-loader?limit=8192'
},
{
test: /\.ts$/,
loader: 'awesome-typescript-loader'
}
]
},
resolve: {
extensions: ['', '.js', '.jsx', '.ts']
}
};
当我 运行 webpack 开发服务器和我的 index.ts 看起来像这样时:
alert('hello');
它指出以下错误:
ERROR in ./ui/index.ts
/Users/..../typings/node/node.d.ts:29:12
Subsequent variable declarations must have the same type. Variable 'require' must be of type 'WebpackRequire', but here has type '{ (id: string): any; resolve(id: string): string; cache: any; extensions: any; main: any; }'.
当我放入参考路径时也是如此。
当我尝试通过 import React = require('react');
导入 React.js 时,它指出:
ERROR in ./ui/index.ts
Module build failed: Cannot resolve module 'child_process' in /..../typings/node
Required in /..../typings/node/node.d.ts
我从 loader 仓库复制了 node.d.ts 文件,还是不行。
有没有人能够让这个组合顺利工作?或者我应该只使用不同的网络打包器吗? 我真的很想让它与 webpack 一起工作。
您可以考虑使用其他 webpack TypeScript loader. I know a few had issues with node stuff. There are also a couple starter kits 可能会有所帮助。
免责声明:我是 ts-loader
.
尝试创建一个 tsconfig.json
文件。
例如,当您使用 awesome-typescript-loader
时,这应该有效:
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"emitDecoratorMetadata": true,
"experimentalDecorators": true,
"sourceMap": true,
"noEmitHelpers": true
},
"exclude": [
"node_modules"
],
"awesomeTypescriptLoaderOptions": {
"forkChecker": true
},
"compileOnSave": false,
"buildOnSave": false,
"atom": { "rewriteTsconfig": false }
}
您只缺少一把钥匙 target: 'node'
。
这可以确保您的目标环境是 Node.js 而不是浏览器,因此会忽略本机依赖项。
最终配置:
module.exports = {
entry: './ui/index.ts',
target: 'node',
output: {
path: __dirname + '/build-ui',
filename: 'app.js',
publicPath: 'http://localhost:8090/assets'
},
module: {
loaders: [
{
test: /\.jsx$/,
loader: 'jsx-loader?insertPragma=React.DOM&harmony'
},
{
test: /\.css$/,
loader: "style-loader!css-loader"
},
{
test: /\.scss$/,
loader: "style-loader!css-loader!sass-loader"
},
{
test: /\.(png|jpg)$/,
loader: 'url-loader?limit=8192'
},
{
test: /\.ts$/,
loader: 'awesome-typescript-loader'
}
]
},
resolve: {
extensions: ['', '.js', '.jsx', '.ts']
}
};