inline-webpack-asset-chunks-plugin

1.0.0 • Public • Published

Inline Webpack Asset Chunks Plugin

This is a webpack plugin that inline your manifest.js with a script tag to save http request. Cause webpack's runtime always change between every build, it's better to split the runtime code out for long-term caching.

Installation

Install the plugin with npm:

$ npm i inline-webpack-asset-chunks-plugin -D

Basic Usage

This plugin need to work with HtmlWebpackPlugin v2.10.0 and above:

Step1: split out the runtime code

// for explicit vendor chunk config
[
	new webpack.optimize.CommonsChunkPlugin({
		names: ['vendor', 'manifest']
	})
]

// or specify which chunk to split manually
[
	new webpack.optimize.CommonsChunkPlugin({
		name: 'manifest',
        chunks: ['...']
	})
]

Step2: config HtmlWebpackPlugin:

[
	new HtmlWebpackPlugin({
		template: './index.ejs'
	})
]

Step3: config InlineWebpackAssetChunksPlugin

  • name: default value is webpackManifest, result in htmlWebpackPlugin.files[name], you can specify any other name except manifest, beacuse the name manifest haved been used by HtmlWebpackPlugin for H5 app cache manifest.
[
	new InlineWebpackAssetChunksPlugin({
		chunkJsList: ['manifest'],
		chunkCssList: ['style']
	})
]
<!-- index.ejs -->
<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<%= htmlWebpackPlugin.files.webpackChunks.style %>
	<title>App</title>
</head>
<body>


<%= htmlWebpackPlugin.files.webpackChunks.manifest %>

</body>
</html>

Done!

Readme

Keywords

none

Package Sidebar

Install

npm i inline-webpack-asset-chunks-plugin

Weekly Downloads

1

Version

1.0.0

License

ISC

Last publish

Collaborators

  • guanyx