Maison >interface Web >Questions et réponses frontales >Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

WBOY
WBOYavant
2022-08-09 15:22:011276parcourir

Cet article vous apporte des connaissances pertinentes sur javascript. Il présente principalement les problèmes liés à la configuration de devServer pour réaliser une compilation en temps réel qui démarre principalement un serveur Http en utilisant Express. j'espère que cela aide tout le monde.

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

[Recommandations associées : tutoriel vidéo javascript, front-end web]

Chaque fois que vous modifiez le code, vous devez le reconditionner, ouvrir le navigateur et l'actualiser, ce qui est très gênant

Nous pouvons installer et utiliser webpackdevserver pour améliorer cette expérience

webpack-dev-server démarre principalement un serveur Http en utilisant express. Sa fonction principale est de servir des fichiers de ressources. De plus, ce serveur et ce client Http utilisent le protocole de communication websocket. Une fois le fichier d'origine modifié, webpack-dev-server le compilera en temps réel, mais le fichier compilé final n'est pas sorti dans le dossier cible, qui est l'original. configuration dans notre sortie ci-dessous. : Le dossier dist est généré après l'empaquetage, mais le répertoire dist n'est pas généré à l'aide de dev-server

output: {
        path: './dist/js',
        filename: 'bundle.js'
    }

Après le démarrage du service, vous constaterez que le répertoire dist a disparu. placez les modules emballés dans le répertoire dist. Au lieu de cela, mettez-le dans la mémoire pour augmenter la vitesse. Installation : npm install webpack-dev-server -D

Modify package.json :

Ensuite, vous pouvez exécuter npm. exécuter le serveur à l'avenir. Démarrez notre service Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Configurez dans webpack.config.js :

Inter-domaine : lors du débogage conjoint, le front-end et le back-end sont séparés et l'obtention directe des données traversera les domaines. .Une fois en ligne, nous utilisons nginx pour le transférer.Pendant le développement, webpack peut le faire Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Scénario d'application : nous avons créé nous-mêmes les interfaces et les données en utilisant express. Lorsque nous accédons à ces interfaces, des problèmes inter-domaines se produisaient. nous avions l'habitude de définir l'en-tête de réponse dans server.js pour autoriser l'inter-domaine. Mais maintenant, vous pouvez également utiliser le proxy devServer.

1. Préparez le service de nœud et créez server.js dans le répertoire racine du projet comme exemple :

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel2. Configurez devServer dans webpack.config, fichier js :

.

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel 3. Installez axios et introduisez-le dans le fichier d'entrée index.js, utilisez axios pour demander les données d'interface

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel Le navigateur frontal obtient le résultat :

Hot Module Le remplacement (HMR : hot Module remplacement) est un module fourni avec webpack et ne nécessite pas d'installation supplémentaire : Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

1) Introduisez webpack dans l'en-tête webpack.config.js du fichier de configuration

const webpack = require("webpack");

2) Ajoutez le dans le fichier de configuration. configuration du plug-in :

plugins: [
    new webpack.HotModuleReplacementPlugin()
]
3) Démarrez hmr

La configuration ci-dessus ne fonctionne pas pour la mise à jour à chaud de js La page sera toujours actualisée lors de l'enregistrement pour avoir l'effet de mise à jour :

Nous avons deux b.js. et fichiers a.js

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réelb Renvoie 1 dans .js

Introduisez b.js dans a.js, et écrivez le résultat de l'exécution des données b + un numéro dans la page

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Dans le fichier d'entrée index.js, introduisez a et exécutez npm run server (notre configuration de mise à jour à chaud reste inchangée)

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Ensuite, nous ouvrons la page, modifions la valeur de b() + 1000 dans a.js, puis ctrl+s pour enregistrer , et constatez que la page s'actualise pour mettre à jour la valeur. Ce n'est évidemment pas ce que nous voulons voir. Pour les mises à jour à chaud de js, nous devons surveiller le fichier à exécuter dans le fichier d'entrée :

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Enregistrer après avoir modifié la valeur dans a.js, sans rafraîchir la page, la valeur sera également La dernière valeur calculée est affichée sur la page

Analyse approfondie de la configuration de devServer pour résoudre les problèmes de compilation en temps réel

Résumé : HMR prend en charge les mises à jour à chaud CSS par défaut, mais nécessite une surveillance séparée pour js

[Recommandations associées : tutoriel vidéo javascript, front-end web]

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer