Partage d'expérience Webpack
webpack est un bundler de modules. Son objectif principal est de regrouper des fichiers JavaScript. Les fichiers packagés sont utilisés dans les navigateurs, mais il peut également être utilisé pour la transformation, le regroupement ou le package. J'espère que certaines de mes expériences pourront vous aider.
Cache
Générer le nom du fichier [name].[contenthash:8].js
, combinez max-age + cdn pour la mise en cache.
Chargement de la page Web
html
était un fichier HTML fixe, html -> numéro de version js (tapé via webpack) -> déterminer le js spécifique via la version nombre . (Cela n'a plus de sens maintenant que j'y pense, même s'il n'est pas si fortement couplé au backend)
Maintenant, c'est le code HTML modifié, qui est tapé via HtmlWebpackPlugin (généré par webpack, contenant js avec numéro de version)
De cette façon, cela permet également d'économiser une heure de série (en extrayant le fichier du numéro de version). Dans le même temps, il est également pratique d'effectuer des niveaux de gris. Par exemple, si vous publiez les exigences, laissez d'abord certains utilisateurs en faire l'expérience, puis tapez dynamiquement le code HTML et envoyez-le en arrière-plan. (Réparer le HTML n'est pas si simple)
Séparation CSS
Dans Guanmai, il y aura très peu de changements CSS, grâce à l'amélioration des noms de classe par React-gm. Comme il y a peu de changements, il n'est pas mauvais de séparer les CSS et d'utiliser ExtractTextPlugin pour séparer les CSS.
Après la séparation, la taille de js est réduite et js n'est pas bloqué. En même temps, css et js peuvent être extraits en même temps.
common
new CommonsChunkPlugin({name: 'commons'})
En regardant le code commun emballé, vous constaterez que les identifiants et les hachages des autres modules seront tapés en commun, de sorte que le fichier commons changera à chaque fois, ce qui rend difficile la mise en cache.
Fournissez simplement deux listes de fichiers et vous constaterez que webpack place l'identifiant et le hachage dans le fichier manifeste. De cette façon, les communs peuvent être mis en cache. Au fait, je n'ai vu aucune introduction sur le site officiel, faites-moi savoir si vous le faites.
new CommonsChunkPlugin({names: ['commons', 'manifest']})
Développement local
Parlons des agents. Les services locaux démarrent par eux-mêmes. Il n'y a pas de service d'arrière-plan, ils doivent donc naturellement être des agents quelque part. Disponible via devServer.proxy. Vous pouvez également utiliser un agent pour accéder au réseau externe afin de rechercher des bogues. Il s'agit uniquement de code source, la vérification des bogues est donc très rapide.
"proxy": { "/ticket/*": { "target": "http://dev.guanmai.cn:7413", "changeOrigin": true } }
Vitesse de packaging
DllPlugin
Lorsque le projet devient volumineux, il nécessitera inévitablement de nombreux packages, ce qui entraînera un temps de packaging très long. L'approche officielle recommandée consiste à transformer les fichiers qui ne changent pas fréquemment en DLL.
Notre projet fera appel à react
react-dom
prop-types
classnames
mobx
mobx-react
lodash
moment
big.js
etc.
Les informations en ligne indiquent que le nom de fichier de la dll est [name]_[hash].dll.js, le nôtre est [npm version]_dll.js npm version
qui est lu par la version package.json.
Pourquoi ne pas utiliser la version hash mais npm ? Nous avons rencontré un problème lors de la réflexion sur le packaging secondaire. Comment juger si la DLL doit être reconditionnée ? Que faire s'il s'agit de hachage (veuillez recommander une solution). Si vous utilisez la version npm, nous reconditionnerons dès que la version change. Par exemple, si React est mis à niveau, nous aurons la version + et le reconditionnerons.
happypack
happypack améliore considérablement la vitesse de construction. Il peut être empaqueté dans plusieurs threads et le cache accélère également la reconstruction.
devtool
eval est utilisé pour le développement et source-map est utilisé pour la production (utilisé pour résoudre les problèmes d'affichage au détriment de la vitesse d'emballage, dans une plage acceptable)
babel-loader
Rappelez-vous cacheDirectory
noParse && alias
Certaines bibliothèques n'ont pas besoin d'être analysées, la configuration noParse n'analyse pas et l'alias pointe vers x.min Fichier .js.
secouement d'arbre
Ce n'est pas encore utilisé, on a l'impression que ce n'est pas encore le bon moment. Il y a un bon article. Votre Tree-Shaking est inutile
Compression
UglifyJsPlugin
Au début, j'utilisais webpack.optimize.UglifyJsPlugin, qui était 1.x à cette fois-là, webpack est basé sur uglify-js@2.x.
Maintenant que Webpack est sorti séparément, il a également beaucoup plus de fonctions. Il prend en charge le cache et la compression multicœur. Je l'ai essayé et c'était assez rapide. webpack.optimize.UglifyJsPlugin est en fait uglifyjs-webpack-plugin.
Ce qui me surprend, c'est que le site officiel dit qu'il est basé sur uglify-es. Mais je pense que la dépendance est toujours uglify-js. étrangeté.
UglifyJsParallelPlugin
Avant la sortie officielle, j'utilisais webpack-uglify-parallel, qui prend en charge le multicœur. La vitesse n'est pas très différente de celle d'uglifyjs-webpack-plugin.
Quand j'ai écrit l'article, j'ai parcouru github et j'ai découvert qu'il avait été abandonné en juillet et intégré au site officiel.
Autres
babel-minify-webpack-plugin de babel, restez à l'écoute.
Script cdn
Certains js (gm-fetch babel-polyfill) ont très peu de changements. L'emballage avec webpack est un peu inutile. Vous pouvez l'obtenir via cdn et mettre le formulaire de script dans le. document html.
Analyse
Il existe des graphiques et des analyses très intuitives. Je le préfère.
webpack-monitor
L'ancien est webpack-bundle-analyzer
Recommandations associées :
Exemple de code Web pour utiliser Webpack pour créer un front-end projets
Résumé des méthodes de configuration du webpack
Explication détaillée des méthodes de configuration npm et webpack dans node.js
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Vue est un excellent framework JavaScript qui peut nous aider à créer rapidement des applications Web interactives et efficaces. Vue3 est la dernière version de Vue, qui introduit de nombreuses nouvelles fonctionnalités et fonctionnalités. Webpack est actuellement l'un des packagers de modules et outils de construction JavaScript les plus populaires, qui peut nous aider à gérer diverses ressources dans nos projets. Cet article explique comment utiliser Webpack pour empaqueter et créer des applications Vue3. 1. Installez Webpack

Utilisation de Jetty7 pour le traitement du serveur Web dans le développement JavaAPI Avec le développement d'Internet, le serveur Web est devenu l'élément central du développement d'applications et est également au centre de l'attention de nombreuses entreprises. Afin de répondre aux besoins croissants des entreprises, de nombreux développeurs choisissent d'utiliser Jetty pour le développement de serveurs Web, et sa flexibilité et son évolutivité sont largement reconnues. Cet article explique comment utiliser Jetty7 dans le développement JavaAPI pour We

La validation du formulaire est un maillon très important dans le développement d'applications Web. Elle permet de vérifier la validité des données avant de soumettre les données du formulaire afin d'éviter les failles de sécurité et les erreurs de données dans l'application. La validation de formulaire pour les applications Web peut être facilement implémentée à l'aide de Golang. Cet article explique comment utiliser Golang pour implémenter la validation de formulaire pour les applications Web. 1. Éléments de base de la validation de formulaire Avant de présenter comment implémenter la validation de formulaire, nous devons savoir quels sont les éléments de base de la validation de formulaire. Éléments de formulaire : les éléments de formulaire sont

Cockpit est une interface graphique Web pour les serveurs Linux. Il est principalement destiné à faciliter la gestion des serveurs Linux pour les utilisateurs nouveaux/experts. Dans cet article, nous aborderons les modes d'accès à Cockpit et comment basculer l'accès administratif à Cockpit depuis CockpitWebUI. Sujets de contenu : Modes d'entrée du cockpit Trouver le mode d'accès actuel au cockpit Activer l'accès administratif au cockpit à partir de CockpitWebUI Désactiver l'accès administratif au cockpit à partir de CockpitWebUI Conclusion Modes d'entrée au cockpit Le cockpit dispose de deux modes d'accès : Accès restreint : il s'agit de la valeur par défaut pour le mode d'accès au cockpit. Dans ce mode d'accès vous ne pouvez pas accéder à l'internaute depuis le cockpit

Les normes Web sont un ensemble de spécifications et de directives développées par le W3C et d'autres organisations associées. Elles incluent la normalisation du HTML, CSS, JavaScript, DOM, l'accessibilité du Web et l'optimisation des performances. En suivant ces normes, la compatibilité des pages peut être améliorée. , maintenabilité et performances. L'objectif des normes Web est de permettre au contenu Web d'être affiché et d'interagir de manière cohérente sur différentes plates-formes, navigateurs et appareils, offrant ainsi une meilleure expérience utilisateur et une meilleure efficacité de développement.

Dans l’ère actuelle de développement rapide d’Internet, PHP, en tant que langage de script côté serveur, est adopté par de plus en plus de développeurs. PHP présente les avantages d'être facile à apprendre, flexible, open source et gratuit, et peut développer rapidement divers sites Web et applications Web. Cependant, en tant que développeur PHP, si vous souhaitez vous démarquer dans une concurrence féroce et écrire du code efficace et stable, vous devez également maîtriser les compétences d'implémentation et l'expérience de diverses fonctions. Tout d’abord, une planification raisonnable de l’architecture du projet est la clé du développement d’applications PHP. Une bonne structure de projet peut fournir une meilleure maintenabilité du code

Le Web est un réseau mondial, également connu sous le nom de World Wide Web, qui est une forme d'application d'Internet. Le Web est un système d'information basé sur l'hypertexte et l'hypermédia, qui permet aux utilisateurs de parcourir et d'obtenir des informations en sautant entre différentes pages Web via des hyperliens. La base du Web est Internet, qui utilise des protocoles et des langages unifiés et standardisés pour permettre l'échange de données et le partage d'informations entre différents ordinateurs.

PHP appartient au backend du développement Web. PHP est un langage de script côté serveur, principalement utilisé pour traiter la logique côté serveur et générer du contenu Web dynamique. Par rapport à la technologie front-end, PHP est davantage utilisé pour les opérations back-end telles que l'interaction avec les bases de données, le traitement des demandes des utilisateurs et la génération du contenu des pages. Ensuite, des exemples de code spécifiques seront utilisés pour illustrer l'application de PHP dans le développement back-end. Tout d'abord, regardons un exemple de code PHP simple pour se connecter à une base de données et interroger des données :
