Table des matières
Cache
Chargement de la page Web
html
Séparation CSS
common
Développement local
Vitesse de packaging
DllPlugin
happypack
devtool
babel-loader
noParse && alias
secouement d'arbre
Compression
UglifyJsPlugin
UglifyJsParallelPlugin
Autres
Script cdn
Analyse
Maison interface Web tutoriel CSS Partage d'expérience Webpack

Partage d'expérience Webpack

Feb 02, 2018 pm 02:28 PM
web 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'})
Copier après la connexion

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']})
Copier après la connexion

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
    }
}
Copier après la connexion

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!

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 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines 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)

Tutoriel de démarrage VUE3 : empaquetage et création avec Webpack Tutoriel de démarrage VUE3 : empaquetage et création avec Webpack Jun 15, 2023 pm 06:17 PM

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 d'API Java Utilisation de Jetty7 pour le traitement du serveur Web dans le développement d'API Java Jun 18, 2023 am 10:42 AM

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

Comment implémenter la validation de formulaire pour les applications Web à l'aide de Golang Comment implémenter la validation de formulaire pour les applications Web à l'aide de Golang Jun 24, 2023 am 09:08 AM

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

Comment activer l'accès administratif à partir de l'interface utilisateur Web du cockpit Comment activer l'accès administratif à partir de l'interface utilisateur Web du cockpit Mar 20, 2024 pm 06:56 PM

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

Que sont les standards du Web ? Que sont les standards du Web ? Oct 18, 2023 pm 05:24 PM

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.

Partage d'expérience en développement PHP : expérience et suggestions pour maîtriser la mise en œuvre de diverses fonctions Partage d'expérience en développement PHP : expérience et suggestions pour maîtriser la mise en œuvre de diverses fonctions Nov 22, 2023 pm 12:02 PM

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

que signifie Internet que signifie Internet Jan 09, 2024 pm 04:50 PM

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 est-il front-end ou back-end dans le développement Web ? PHP est-il front-end ou back-end dans le développement Web ? Mar 24, 2024 pm 02:18 PM

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 :

See all articles