Webpack Build不渲染HTML5视频

时间:2018-03-05 04:41:37

标签: javascript html5 reactjs webpack webpack.config.js

- 我有一个在localhost(开发环境)下正确加载的HTML5视频。

反应组件

import HomeVideo from '../video/home.mp4';
const Home = () => (
  <div className="home-container">
    <div className='video-container'>
    </div>
    <video autoPlay loop>
      <source src={HomeVideo} type='video/mp4' />
      Your browser does not support the video tag.<a href="https://youtu.be/bgSMpRpObCg" rel="noopener noreferrer" target="_blank">Watch it here</a>
    </video>
  </div>
  </div>    
)
export default Home;
  • 视频在DEV中正确加载:

enter image description here

  • 我运行npm run build我的webpack -p处理所有内容。

的package.json

"scripts": {
    "start": "webpack-dev-server --devtool eval-source-map --history-api-fallback --open",
    "build": "webpack -p"
  },
  • 使用生产版本,我在控制台中看到了视频(但是src=显示了webpack构建网址)这是问题吗?

enter image description here

  • 视频会在页面中加载

enter image description here

这些是我当前编写的webpack.config.js的方式: ps:无论有没有注释掉的行,行为仍然是相同的。在dev中工作,在构建之后不起作用。

const webpack = require('webpack');

module.exports = {
  entry: `${__dirname}/src/index.js`,
  output: {
    path: `${__dirname}/build`,
    publicPath: '/build/',
    filename: 'bundle.js',
  },


  module: {
    rules: [
      //{ test: /\.html$/, loader: 'html-loader?attrs[]=video:src' },
      //{ test: /\.(mov|mp4)$/, loader: 'url-loader?limit=10000&mimetype=video/mp4' },
      {
        test: /\.(mov|mp4)$/, use: [
          {
            loader: 'file-loader',
            options: {
              name: '[path][name].[ext]'
            }
          }
        ]
      },
      { test: /\.js$/, exclude: /node_modules/, loader: 'babel-loader' },
      {
        test: /\.css$/,
        use: ['style-loader', { loader: 'css-loader', options: { minimize: true } }],
      },
      {
        test: /\.(pdf|jpg|png|svg)$/,
        use: {
          loader: "file-loader",
          options: {
            name: "[path][name].[hash].[ext]",
          },
        },
      },
    ]
  },

  plugins: process.argv.indexOf('-p') === -1 ? [] : [
    new webpack.optimize.UglifyJsPlugin({
      output: {
        comments: false,
      },
    }),
  ],
};

**我不知道这是否重要,但这是在GitHub网页上提供的。

1 个答案:

答案 0 :(得分:3)

使用以下网络包配置。(取消注释下面的行,删除/\.(mov|mp4)的限制

  { test: /\.html$/, loader: 'html-loader?attrs[]=video:src' },
  { test: /\.(mov|mp4)$/, loader: 'url-loader' },

请检查相似类型的问题here

并查看有关url-loaderhtml-loader的更多信息。

希望这会对你有所帮助!!