javascript - Webpack 构建不渲染 HTML5 视频

标签 javascript html reactjs webpack webpack.config.js

-- 我有一个 HTML5 视频,可以在本地主机(开发环境)中正确加载。

react 组件

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 构建 url)这是问题所在吗?

enter image description here

  • 但视频无法加载到页面中。

enter image description here

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

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 页面上提供。

最佳答案

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

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

请检查与 here 类似类型的问题。

还可以查看有关 url-loaderhtml-loader 的更多信息。

希望这对你有帮助!!

关于javascript - Webpack 构建不渲染 HTML5 视频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49103589/

相关文章:

javascript - Mozilla Persona/BrowserID 电子邮件地址和 cookie

javascript - Shadowbox 未加载/工作

javascript - 不能在 javascript 中使用 "download"作为函数名

html - 删除 html 列表中的填充

html - CSS 网格 - 为什么 "justify-items"变灰但有效?

javascript - Javascript 中的函数重载 - 最佳实践

html - float DIV 旁边的 block 引用格式中断

javascript - 单击按钮时禁用蓝色描边效果

node.js - 上传文件时: CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource

reactjs - create-react-app 中 EXTEND_ESLINT=true 时 typescript 解析错误