6

我正在尝试配置 webpack,以便它解析我的index.html(最好使用 HTMLWebpack 插件),以便将任何包含的图像(例如<object data="images/test.svg">)移动到我的输出文件夹,文件夹路径保持不变。最终,运行 webpack-dev-server 应该会呈现一个显示我的图像的页面。

这个问题有点相关,但与我自己的问题不太匹配。

我试图做的事情:

从我的配置文件中可以看出,我尝试使用 html-loader。没有exclude: /index\.html$/它会给我一个错误。我的猜测是 HTMLWebpack 插件和 html-loader 不能相处。排除 index.html 违背了 html-loader 的目的。文件加载器无法识别使用require(image).

当前发生的情况:一切运行良好,但没有图像文件夹,也没有/dist/.

我当前的webpack.config.js

var HtmlWebpackPlugin = require('html-webpack-plugin');
var HTMLWebpackPluginConfig = new HtmlWebpackPlugin({
  template: __dirname + '/app/index.html',
  filename: 'index.html',
  inject: 'body'
});

module.exports = {
  entry: './app/index.js',

  output: {
    path: __dirname + '/dist',
    publicPath: '/dist',
    filename: 'index_bundle.js'
  },

  module: {
    loaders: [
    { test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader'},
    { test: /\.svg$/, loader: 'file-loader' },
    { test: /\.html$/, exclude: /index\.html$/, loader: 'html-loader'}
    ]
  },

  plugins: [
    HTMLWebpackPluginConfig
  ]
}

示例index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Test</title>
</head>
<body>
    <div id="demoSpace"><object data="images/test.svg"  type="image/svg+xml"></object></div>
    <div id="test"></div> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js">      
    </script>
</body>
</html>
4

1 回答 1

0

我对我在 html-loader 文档中看到的内容的看法是,它将默认自动生成require它在“img”标签中找到的内容。由于您正在处理“对象”标签,您可能希望专注于讨论的标签属性处理功能:

您可以通过查询参数 attrs 指定此加载器应处理的标记属性组合。传递数组或空格分隔的 : 组合列表。(默认:attrs=img:src)

于 2016-11-18T06:06:17.690 回答