GitXplorerGitXplorer
e

inert-entry-webpack-plugin

public
7 stars
1 forks
0 issues

Commits

List of commits on branch master.
Unverified
ade93ef772a6b76bb3735c1898394e082d1d7c66

4.0.1

eerikdesjardins committed 7 years ago
Unverified
9cd42e8190797f7ae1a4b3d14f25dd796fdd3078

don't generate broken `RawSource(undefined)`

eerikdesjardins committed 7 years ago
Verified
14d67d75fdd7b45948000a70908fa98cff000c53

Merge pull request #19 from erikdesjardins/webpack4

eerikdesjardins committed 7 years ago
Unverified
9d8ac49d711f52428859ac1faa12b017d89ed93f

4.0.0

eerikdesjardins committed 7 years ago
Unverified
019ab22dd432305774738c7a10a9c3e2e3e7fc5a

can't use object spread

eerikdesjardins committed 7 years ago
Unverified
99b71fccb470757251efa1230eb6b8673ab38c4e

rewrite for webpack 4

eerikdesjardins committed 7 years ago

README

The README file for this repository.

inert-entry-webpack-plugin

Webpack plugin to allow non-js entry chunks.

Webpack requires that all entry chunks emit valid JS. However, sometimes you want to use HTML or a manifest file as your entry point.

This plugin allows the use of any non-JS ("inert") file in an entry chunk, and prevents Webpack from adding its wrapper to those chunks. This only affects the main compiler, not any child compilers.

Use entry-loader or spawn-loader to emit normal entry points for JS files required in your HTML or manifest files.

Installation

npm install --save-dev inert-entry-webpack-plugin

Usage

webpack.config.js:

var InertEntryPlugin = require('inert-entry-webpack-plugin');

module.exports = {
  entry: {
    nameOfEntryChunk: 'index.html'
  },
  output: {
    path: path.join(__dirname, 'dist'),
    filename: '[name].[hash].html'
  },
  module: {
    rules: [
      { test: /\.html$/, use: ['extract-loader', { loader: 'html-loader', options: { attrs: ['link:href', 'script:src'] } }] },
      { test: /\.css$/, use: ['file-loader', 'extract-loader', 'css-loader'] }
    ]
  },
  plugins: [
    new InertEntryPlugin()
  ]
  // ...
};

index.html:

<html>
<head>
  <link rel="stylesheet" href="./main.css" type="text/css">
  <script src="entry-loader!app.js"></script>
</head>
<body>...</body>
</html>

Output

nameOfEntryChunk.0dcbbaa701328a3c262cfd45869e351f.html:

<html>
<head>
  <link rel="stylesheet" href="e43b20c069c4a01867c31e98cbce33c9.css" type="text/css">
  <script src="main.bundle.js"></script>
</head>
<body>...</body>
</html>

Notice that Webpack's wrapper is not present, as you would expect for an entry chunk.

main.bundle.js will contain the wrapper, however, because it's loaded with entry-loader.