Heim >Web-Frontend >js-Tutorial >Analysieren Sie das Webpack korrekt, um Bibliotheken von Drittanbietern zu extrahieren

Analysieren Sie das Webpack korrekt, um Bibliotheken von Drittanbietern zu extrahieren

小云云
小云云Original
2017-12-23 14:57:411761Durchsuche

Wenn wir Webpack zum Packen verwenden, möchten wir häufig die Bibliothek eines Drittanbieters separat extrahieren, sie als stabile Versionsdatei verwenden und den Browser-Cache verwenden, um die Anzahl der Anforderungen zu reduzieren. Es gibt zwei häufig verwendete Methoden zum Extrahieren von Bibliotheken von Drittanbietern. In diesem Artikel wird hauptsächlich die korrekte Vorgehensweise beim Extrahieren von Bibliotheken von Drittanbietern vorgestellt. Es gibt zwei häufig verwendete Methoden zum Extrahieren von Bibliotheken von Drittanbietern Für diejenigen, die interessiert sind, können Sie mehr darüber erfahren. Ich hoffe, es kann allen helfen.

  1. CommonsChunkPlugin

  2. DLLPlugin

Unterschied: Der erste Typ muss jedes Mal gepackt werden. Der dritte -Party-Bibliothek führt das Packen auch jedes Mal nur einmal aus. Wir müssen nur die komprimierte Datei des Drittanbieters zum ersten Mal zitieren

CommonsChunkPlugin-Methodeneinführung

Nehmen wir Vue als Beispiel


const vue = require('vue')
{
 entry: {
 // bundle是我们要打包的项目文件的导出名字, app是入口js文件
 bundle: 'app',
 // vendor就是我们要打包的第三方库最终生成的文件名,数组里是要打包哪些第三方库, 如果不是在node——modules里面,可以填写库的具体地址
 vendor: ['vue']
 },
 output: {
  path: __dirname + '/bulid/',
 // 文件名称
 filename: '[name].js'
 },
 plugins: {
 // 这里实例化webpack.optimize.CommonsChunkPlugin构造函数
 // 打包之后就生成vendor.js文件
 new webpack.optimize.CommonsChunkPlugin('vendor', 'vendor.js')
 }
}

Verpacken Sie dann die generierte Datei und importieren Sie sie in die HTML-Datei


<script src="/build/vendor.js"></script>
 <script src="/build/bundle.js"></script>

Einführung in die DLLPlugin-Methode

Bereiten Sie zunächst zwei Dateien vor

  1. webpack.config.js

  2. webpack.dll.config.js

Die Datei webpack.dll.config.js ist wie folgt konfiguriert


const webpack = require(&#39;webpack&#39;)
const library = &#39;[name]_lib&#39;
const path = require(&#39;path&#39;)

module.exports = {
 entry: {
 vendors: [&#39;vue&#39;, &#39;vuex&#39;]
 },

 output: {
 filename: &#39;[name].dll.js&#39;,
 path: &#39;dist/&#39;,
 library
 },

 plugins: [
 new webpack.DllPlugin({
  path: path.join(__dirname, &#39;dist/[name]-manifest.json&#39;),
  // This must match the output.library option above
  name: library
 }),
 ],
}

Dann wird die Datei webpack.config.js wie folgt konfiguriert


const webpack = require(&#39;webpack&#39;)

module.exports = {
 entry: {
 app: &#39;./src/index&#39;
 },
 output: {
 filename: &#39;app.bundle.js&#39;,
 path: &#39;dist/&#39;,
 },
 plugins: [
 new webpack.DllReferencePlugin({
  context: __dirname,
  manifest: require(&#39;./dist/vendors-manifest.json&#39;)
 })
 ]
}

Dann führen Sie


aus

$ webpack --config webpack.dll.config.js
$ webpack --config webpack.config.js

HTML-Referenzmethode


<script src="/dist/vendors.dll.js"></script>
<script src="/dist/app.bundle.js"></script>

Verwandte Empfehlungen:

Detaillierte Erläuterung des Unterschieds zwischen Webpack require.ensure und AMD_javascript-Kenntnissen

Detaillierte Erläuterung der Vue-On-Demand-Ladekomponente Webpack require.ensure

Webpack-Lerntutorial vorne -Zusammenfassung der Leistungsoptimierung

Das obige ist der detaillierte Inhalt vonAnalysieren Sie das Webpack korrekt, um Bibliotheken von Drittanbietern zu extrahieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn