Maison interface Web js tutoriel Introduction à la configuration d'optimisation de Webpack pour restreindre la portée de la recherche de fichiers

Introduction à la configuration d'optimisation de Webpack pour restreindre la portée de la recherche de fichiers

Jun 30, 2018 pm 02:47 PM
webpack 优化

Cet article présente principalement les connaissances sur l'optimisation de Webpack en réduisant la portée de la recherche de fichiers. L'article présente les moyens d'optimiser plus en détail. Les amis dans le besoin peuvent s'y référer

Webpack commencera à partir de. configurée, les instructions d'importation dans le fichier sont analysées, puis analysées de manière récursive.

Lorsqu'il rencontre une instruction d'importation, Webpack fera deux choses :

1. Recherchez le fichier correspondant à importer en fonction de l'instruction d'importation. Par exemple, le fichier correspondant à l'instruction d'importation require('react') est ./node_modules/react/react.js, et le fichier correspondant à require('./util') est ./util.js.

2. Utilisez le Loader dans la configuration pour traiter le fichier en fonction du suffixe trouvé du fichier à importer. Par exemple, les fichiers JavaScript développés avec ES6 doivent être traités à l'aide de babel-loader.

Bien que les deux choses ci-dessus soient très rapides pour traiter un fichier, lorsque le projet devient volumineux, le nombre de fichiers deviendra très important et le problème de la vitesse de construction lente sera exposé.

Bien que les deux choses ci-dessus ne puissent être évitées, elles doivent être minimisées pour augmenter la vitesse.

Ce qui suit présentera les moyens de les optimiser une par une.

Optimiser la configuration du chargeur

L'opération de conversion des fichiers par Loader prenant du temps, il est nécessaire d'autoriser le moins de fichiers possible à traiter par Loader.

Dans le module 2-3, il a été introduit que lors de l'utilisation de Loader, vous pouvez utiliser les trois éléments de configuration tester, inclure et exclure pour accéder aux fichiers auxquels Loader souhaite appliquer des règles.

Afin de permettre au moins de fichiers possible d'être traité par Loader, vous pouvez utiliser include pour cibler uniquement les fichiers qui doivent être traités.

Prenons un projet utilisant ES6 comme exemple. Lors de la configuration de babel-loader, vous pouvez faire ceci :

module.exports = {
 module: {
  rules: [
   {
    // 如果项目源码中只有 js 文件就不要写成 /\.jsx?$/,提升正则表达式性能
    test: /\.js$/,
    // babel-loader 支持缓存转换出的结果,通过 cacheDirectory 选项开启
    use: ['babel-loader?cacheDirectory'],
    // 只对项目根目录下的 src 目录中的文件采用 babel-loader
    include: path.resolve(__dirname, 'src'),
   },
  ]
 },
};
Copier après la connexion

Vous pouvez ajuster la structure des répertoires du projet de manière appropriée pour faciliter la configuration de. le chargeur est inclus pour réduire la plage de frappe.

Optimiser la configuration de solve.modules

Introduit dans 2-4 Resolve, solve.modules est utilisé pour configurer Webpack quels répertoires doivent. être recherché dans le module Tiers.

La valeur par défaut de solve.modules est ['node_modules'] , ce qui signifie qu'il faut d'abord aller dans le répertoire ./node_modules dans le répertoire actuel pour trouver le module que vous recherchez. S'il n'est pas trouvé, allez en haut. -répertoire de niveau ../node_modules Sinon, recherchez dans ../../node_modules, et ainsi de suite. Ceci est très similaire au mécanisme de recherche de module de Node.js.

Lorsque les modules tiers installés sont placés dans le répertoire ./node_modules sous le répertoire racine du projet, il n'est pas nécessaire de rechercher couche par couche de la manière par défaut. Vous pouvez spécifier le chemin absolu pour stocker le. module tiers. Pour réduire les recherches, la configuration est la suivante :

module.exports = {
 resolve: {
  // 使用绝对路径指明第三方模块存放的位置,以减少搜索步骤
  // 其中 __dirname 表示当前工作目录,也就是项目根目录
  modules: [path.resolve(__dirname, 'node_modules')]
 },
};
Copier après la connexion

Optimiser la configuration de solve.mainFields

resolve.mainFields. a été introduit dans 2-4 Résoudre Utilisé pour configurer le fichier d'entrée utilisé par le module tiers.

Le module tiers installé aura un fichier package.json utilisé pour décrire les propriétés du module. Certains champs sont utilisés pour décrire où se trouve le fichier d'entrée solve.mainFields est utilisé pour configurer lequel. Le champ est utilisé comme description du fichier d’entrée.

La raison pour laquelle il peut y avoir plusieurs champs décrivant le fichier d'entrée est que certains modules peuvent être utilisés dans plusieurs environnements en même temps et que différents codes doivent être utilisés pour différents environnements d'exploitation.

Prenons l'exemple d'isomorphic-fetch, qui est une implémentation de l'API fetch mais peut être utilisée à la fois dans les environnements de navigateur et Node.js.

Il y a 2 champs de description de fichier d'entrée dans son package.json :

{
 "browser": "fetch-npm-browserify.js",
 "main": "fetch-npm-node.js"
}
Copier après la connexion

isomorphic-fetch utilise différents codes dans différents environnements d'exécution en raison du mécanisme d'implémentation de l'API fetch La différence. est qu'il est implémenté dans le navigateur via la récupération native ou XMLHttpRequest, et dans Node.js via le module http.

La valeur par défaut de solve.mainFields est liée à la configuration actuelle de la cible. La relation correspondante est la suivante :

  • Lorsque la cible est web ou webworker, la valeur. est ["browser", "module", "main"]

  • Lorsque la cible est d'autres situations, la valeur est ["module", "main"]

En prenant comme exemple target égal à web, Webpack utilisera d'abord le champ du navigateur dans le module tiers pour trouver le fichier d'entrée du module. S'il n'existe pas, il utilisera le module. champ, et ainsi de suite.

Afin de réduire les étapes de recherche, lorsque vous précisez le champ de description du fichier d'entrée du module tiers, vous pouvez le paramétrer le moins possible.

Étant donné que la plupart des modules tiers utilisent le champ principal pour décrire l'emplacement du fichier d'entrée, Webpack peut être configuré comme ceci :

module.exports = {
 resolve: {
  // 只采用 main 字段作为入口文件描述字段,以减少搜索步骤
  mainFields: ['main'],
 },
};
Copier après la connexion

Lors de l'optimisation à l'aide de cette méthode, vous devez considérer tous les temps d'exécution Dans le champ de description du fichier d'entrée du module tiers dépendant, même si un module est erroné, le code construit peut ne pas s'exécuter normalement.

Optimiser la configuration de solve.alias

Introduit dans 2-4 Resolve, l'élément de configuration de solve.alias mappe le chemin d'importation d'origine via des alias dans un nouveau chemin d'importation.

Dans les projets réels, nous nous appuyons souvent sur d'énormes modules tiers. En prenant la bibliothèque React comme exemple, la structure des répertoires de la bibliothèque React installée dans le répertoire node_modules est la suivante :

├── dist
│ ├── react.js
│ └── react.min.js
├── lib
│ ... 还有几十个文件被忽略
│ ├── LinkedStateMixin.js
│ ├── createClass.js
│ └── React.js
├── package.json
└── react.js

可以看到发布出去的 React 库中包含两套代码:

  • 一套是采用 CommonJS 规范的模块化代码,这些文件都放在 lib 目录下,以 package.json 中指定的入口文件 react.js 为模块的入口。

  • 一套是把 React 所有相关的代码打包好的完整代码放到一个单独的文件中,这些代码没有采用模块化可以直接执行。其中 dist/react.js 是用于开发环境,里面包含检查和警告的代码。 dist/react.min.js 是用于线上环境,被最小化了。

默认情况下 Webpack 会从入口文件 ./node_modules/react/react.js 开始递归的解析和处理依赖的几十个文件,这会时一个耗时的操作。

通过配置 resolve.alias 可以让 Webpack 在处理 React 库时,直接使用单独完整的 react.min.js 文件,从而跳过耗时的递归解析操作。

相关 Webpack 配置如下:

module.exports = {
 resolve: {
  // 使用 alias 把导入 react 的语句换成直接使用单独完整的 react.min.js 文件,
  // 减少耗时的递归解析操作
  alias: {
   'react': path.resolve(__dirname, './node_modules/react/dist/react.min.js'),
  }
 },
};
Copier après la connexion

除了 React 库外,大多数库发布到 Npm 仓库中时都会包含打包好的完整文件,对于这些库你也可以对它们配置 alias。
但是对于有些库使用本优化方法后会影响到后面要讲的 使用 Tree-Shaking 去除无效代码 的优化,因为打包好的完整文件中有部分代码你的项目可能永远用不上。

一般对整体性比较强的库采用本方法优化,因为完整文件中的代码是一个整体,每一行都是不可或缺的。

但是对于一些工具类的库,例如 lodash ,你的项目可能只用到了其中几个工具函数,你就不能使用本方法去优化,因为这会导致你的输出代码中包含很多永远不会执行的代码。

优化 resolve.extensions 配置

在导入语句没带文件后缀时,Webpack 会自动带上后缀后去尝试询问文件是否存在。

在 2-4 Resolve 中介绍过 resolve.extensions 用于配置在尝试过程中用到的后缀列表,默认是:

extensions: ['.js', '.json']
Copier après la connexion

也就是说当遇到 require('./data') 这样的导入语句时,Webpack 会先去寻找 ./data.js 文件,如果该文件不存在就去寻找 ./data.json 文件,如果还是找不到就报错。

如果这个列表越长,或者正确的后缀在越后面,就会造成尝试的次数越多,所以 resolve.extensions 的配置也会影响到构建的性能。

在配置 resolve.extensions 时你需要遵守以下几点,以做到尽可能的优化构建性能:

  • 后缀尝试列表要尽可能的小,不要把项目中不可能存在的情况写到后缀尝试列表中。

  • 频率出现最高的文件后缀要优先放在最前面,以做到尽快的退出寻找过程。

  • 在源码中写导入语句时,要尽可能的带上后缀,从而可以避免寻找过程。例如在你确定的情况下把 require('./data') 写成 require('./data.json') 。

相关 Webpack 配置如下:

module.exports = {
 resolve: {
  // 尽可能的减少后缀尝试的可能性
  extensions: ['js'],
 },
};
Copier après la connexion

优化 module.noParse 配置

在 2-3 Module 中介绍过 module.noParse 配置项可以让 Webpack 忽略对部分没采用模块化的文件的递归解析处理,这样做的好处是能提高构建性能。

原因是一些库,例如 jQuery 、ChartJS, 它们庞大又没有采用模块化标准,让 Webpack 去解析这些文件耗时又没有意义。

在上面的 优化 resolve.alias 配置 中讲到单独完整的 react.min.js 文件就没有采用模块化,让我们来通过配置 module.noParse 忽略对 react.min.js 文件的递归解析处理,

相关 Webpack 配置如下:

const path = require('path');
module.exports = {
 module: {
  // 独完整的 `react.min.js` 文件就没有采用模块化,忽略对 `react.min.js` 文件的递归解析处理
  noParse: [/react\.min\.js$/],
 },
};
Copier après la connexion

注意被忽略掉的文件里不应该包含 import 、 require 、 define 等模块化语句,不然会导致构建出的代码中包含无法在浏览器环境下执行的模块化语句。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

Webpack的dll功能的使用

Vue-cli proxyTable如何解决开发环境的跨域问题

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment optimiser les paramètres et améliorer les performances après avoir reçu un nouvel ordinateur Win11 ? Comment optimiser les paramètres et améliorer les performances après avoir reçu un nouvel ordinateur Win11 ? Mar 03, 2024 pm 09:01 PM

Comment configurer et optimiser les performances après avoir reçu un nouvel ordinateur ? Les utilisateurs peuvent directement ouvrir Confidentialité et sécurité, puis cliquer sur Général (ID publicitaire, Contenu local, Lancement de l'application, Recommandations de configuration, Outils de productivité ou ouvrir directement la stratégie de groupe locale. Utilisez simplement le éditeur pour effectuer l'opération. Permettez-moi de présenter aux utilisateurs en détail comment optimiser les paramètres et améliorer les performances du nouvel ordinateur Win11 après l'avoir reçu : 1. Appuyez sur la combinaison de touches [Win+i] pour ouvrir Paramètres, puis cliquez sur. [Confidentialité et sécurité] sur la gauche, puis cliquez sur [Général (identifiant publicitaire, contenu local, lancement d'application, suggestions de paramètres, productivité) sous Autorisations Windows à droite Outils)].

Interprétation approfondie : Pourquoi Laravel est-il aussi lent qu'un escargot ? Interprétation approfondie : Pourquoi Laravel est-il aussi lent qu'un escargot ? Mar 07, 2024 am 09:54 AM

Laravel est un framework de développement PHP populaire, mais il est parfois critiqué pour sa lenteur comme un escargot. Qu'est-ce qui cause exactement la vitesse insatisfaisante de Laravel ? Cet article fournira une explication détaillée des raisons pour lesquelles Laravel est aussi lent qu'un escargot sous plusieurs aspects, et la combinera avec des exemples de code spécifiques pour aider les lecteurs à mieux comprendre ce problème. 1. Problèmes de performances des requêtes ORM Dans Laravel, ORM (Object Relational Mapping) est une fonctionnalité très puissante qui permet

Discussion sur la stratégie d'optimisation gc de Golang Discussion sur la stratégie d'optimisation gc de Golang Mar 06, 2024 pm 02:39 PM

Le garbage collection (GC) de Golang a toujours été un sujet brûlant parmi les développeurs. En tant que langage de programmation rapide, le garbage collector intégré de Golang peut très bien gérer la mémoire, mais à mesure que la taille du programme augmente, certains problèmes de performances surviennent parfois. Cet article explorera les stratégies d'optimisation GC de Golang et fournira quelques exemples de code spécifiques. La collecte des déchets dans le garbage collector de Golang Golang est basée sur un balayage de marque simultané (concurrentmark-s

Optimisation des programmes C++ : techniques de réduction de la complexité temporelle Optimisation des programmes C++ : techniques de réduction de la complexité temporelle Jun 01, 2024 am 11:19 AM

La complexité temporelle mesure le temps d'exécution d'un algorithme par rapport à la taille de l'entrée. Les conseils pour réduire la complexité temporelle des programmes C++ incluent : le choix des conteneurs appropriés (tels que vecteur, liste) pour optimiser le stockage et la gestion des données. Utilisez des algorithmes efficaces tels que le tri rapide pour réduire le temps de calcul. Éliminez les opérations multiples pour réduire le double comptage. Utilisez des branches conditionnelles pour éviter les calculs inutiles. Optimisez la recherche linéaire en utilisant des algorithmes plus rapides tels que la recherche binaire.

Décoder les goulots d'étranglement des performances de Laravel : les techniques d'optimisation entièrement révélées ! Décoder les goulots d'étranglement des performances de Laravel : les techniques d'optimisation entièrement révélées ! Mar 06, 2024 pm 02:33 PM

Décoder les goulots d'étranglement des performances de Laravel : les techniques d'optimisation entièrement révélées ! Laravel, en tant que framework PHP populaire, offre aux développeurs des fonctions riches et une expérience de développement pratique. Cependant, à mesure que la taille du projet augmente et que le nombre de visites augmente, nous pouvons être confrontés au défi des goulots d'étranglement en matière de performances. Cet article approfondira les techniques d'optimisation des performances de Laravel pour aider les développeurs à découvrir et à résoudre les problèmes de performances potentiels. 1. Optimisation des requêtes de base de données à l'aide du chargement différé d'Eloquent Lorsque vous utilisez Eloquent pour interroger la base de données, évitez

Le goulot d'étranglement des performances de Laravel révélé : la solution d'optimisation révélée ! Le goulot d'étranglement des performances de Laravel révélé : la solution d'optimisation révélée ! Mar 07, 2024 pm 01:30 PM

Le goulot d'étranglement des performances de Laravel révélé : la solution d'optimisation révélée ! Avec le développement de la technologie Internet, l’optimisation des performances des sites Web et des applications est devenue de plus en plus importante. En tant que framework PHP populaire, Laravel peut être confronté à des goulots d'étranglement en termes de performances pendant le processus de développement. Cet article explorera les problèmes de performances que les applications Laravel peuvent rencontrer et fournira des solutions d'optimisation et des exemples de code spécifiques afin que les développeurs puissent mieux résoudre ces problèmes. 1. Optimisation des requêtes de base de données Les requêtes de base de données sont l'un des goulots d'étranglement de performances courants dans les applications Web. exister

Comment optimiser les éléments de démarrage du système WIN7 Comment optimiser les éléments de démarrage du système WIN7 Mar 26, 2024 pm 06:20 PM

1. Appuyez sur la combinaison de touches (touche Win + R) sur le bureau pour ouvrir la fenêtre d'exécution, puis entrez [regedit] et appuyez sur Entrée pour confirmer. 2. Après avoir ouvert l'éditeur de registre, nous cliquons pour développer [HKEY_CURRENT_USERSoftwareMicrosoftWindowsCurrentVersionExplorer], puis voyons s'il y a un élément Sérialiser dans le répertoire. Sinon, nous pouvons cliquer avec le bouton droit sur Explorateur, créer un nouvel élément et le nommer Sérialiser. 3. Cliquez ensuite sur Sérialiser, puis cliquez avec le bouton droit sur l'espace vide dans le volet de droite, créez une nouvelle valeur de bit DWORD (32) et nommez-la Étoile.

La configuration des paramètres du Vivox100 révélée : Comment optimiser les performances du processeur ? La configuration des paramètres du Vivox100 révélée : Comment optimiser les performances du processeur ? Mar 24, 2024 am 10:27 AM

La configuration des paramètres du Vivox100 révélée : Comment optimiser les performances du processeur ? À l’ère actuelle de développement technologique rapide, les smartphones sont devenus un élément indispensable de notre vie quotidienne. En tant qu'élément important d'un smartphone, l'optimisation des performances du processeur est directement liée à l'expérience utilisateur du téléphone mobile. En tant que smartphone haut de gamme, la configuration des paramètres du Vivox100 a attiré beaucoup d'attention, en particulier l'optimisation des performances du processeur a attiré beaucoup d'attention de la part des utilisateurs. En tant que « cerveau » du téléphone mobile, le processeur affecte directement la vitesse de fonctionnement du téléphone mobile.

See all articles