我试图自动化资产进入/dist。我有以下config.js:
module.exports = {
context: __dirname + "/lib",
entry: {
main: [
"./baa.ts"
]
},
output: {
path: __dirname + "/dist",
filename: "foo.js"
},
devtool: "source-map",
module: {
loaders: [
{
test: /\.ts$/,
loader: 'awesome-typescript-loader'
},
{ test: /\.css$/, loader: "style-loader!css-loader" }
]
},
resolve: {
// you can now require('file') instead of require('file.js')
extensions: ['', '.js', '.json']
}
}
我还想包括main.html从目录,坐在旁边/lib,到/dist文件夹时运行webpack。我该怎么做呢?
更新1 2017_____________
现在我最喜欢的方法是使用带有模板文件的html-webpack-plugin。也感谢公认的答案!这种方法的优点是,索引文件也将有cachbusted js链接添加开箱即用!
选项1
在你的index.js文件(即webpack条目)中,通过文件加载器插件在index.html中添加一个require,例如:
require(“file-loader ? name = [name]。[请拨分机!’…- index . html);
一旦你用webpack构建了你的项目,index.html就会在输出文件夹中。
选项2
使用html-webpack-plugin来避免使用index.html。简单地让webpack为你生成文件。
在这种情况下,如果你想保留自己的index.html文件作为模板,你可以使用这样的配置:
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
// ...
plugins: [
new HtmlWebpackPlugin({
template: 'src/index.html'
})
]
}
更多信息请参见文档。
要扩展@hobbeshunter的答案,如果你只想要index.html,你也可以使用CopyPlugin,
使用这种方法而不是使用其他包的主要动机是,为每一种类型添加许多包并对其进行配置等是一场噩梦。
最简单的方法是使用CopyPlugin所有东西:
npm install copy-webpack-plugin --save-dev
然后
const CopyPlugin = require('copy-webpack-plugin');
module.exports = {
plugins: [
new CopyPlugin([
{ from: 'static', to: 'static' },
{ from: 'index.html', to: 'index.html', toType: 'file'},
]),
],
};
正如你所看到的,它复制了整个静态文件夹连同它的所有内容到dist文件夹。
不需要css或文件或任何其他插件。
虽然这种方法并不适用于所有的事情,但它可以简单而快速地完成工作。
选项1
在你的index.js文件(即webpack条目)中,通过文件加载器插件在index.html中添加一个require,例如:
require(“file-loader ? name = [name]。[请拨分机!’…- index . html);
一旦你用webpack构建了你的项目,index.html就会在输出文件夹中。
选项2
使用html-webpack-plugin来避免使用index.html。简单地让webpack为你生成文件。
在这种情况下,如果你想保留自己的index.html文件作为模板,你可以使用这样的配置:
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports = {
// ...
plugins: [
new HtmlWebpackPlugin({
template: 'src/index.html'
})
]
}
更多信息请参见文档。