Maison > interface Web > js tutoriel > Comment vue-cli et webpack gèrent les ressources statiques

Comment vue-cli et webpack gèrent les ressources statiques

小云云
Libérer: 2018-05-15 16:18:37
original
2110 Les gens l'ont consulté

Traitement des ressources statiques

Vous remarquerez peut-être que dans les projets qui combinent vue-cli avec webpack, nous avons généralement deux chemins de ressources statiques : src/assets et static/ , quel est le différence entre eux ? Cet article présente principalement comment vue-cli et webpack sont combinés pour gérer les ressources statiques. L'éditeur pense que c'est plutôt bien, je vais donc le partager avec vous maintenant et le donner comme référence. Suivons l'éditeur et jetons un œil. J'espère que cela pourra aider tout le monde.

Ressources packagées

Afin de répondre à cette question, nous devons d'abord comprendre comment Webpack gère les ressources statiques. Dans le composant *.vue, tous les modèles et modules CSS sont analysés par vue-html-loader et css-loader pour trouver l'URL du chemin.

Par exemple, dans et background: url(./logo.png), "./logo.png" est un chemin relatif, qui sera chargé en tant que dépendance par Webpack.

Mais comme logo.png n'est pas JavaScript, s'il est considéré comme une fleur dépendante, nous devons l'analyser via le chargeur d'URL et le chargeur de fichiers. Ce modèle a déjà configuré le chargeur correspondant pour vous, vous n'avez donc généralement pas à vous soucier des problèmes de déploiement de chemin relatif.

Même si ces ressources peuvent être intégrées/copiées/renommées pendant le processus de construction, elles constituent toujours une partie importante du code source. C'est pourquoi nous vous recommandons de placer les ressources statiques dans un dossier /src séparé, comme les autres dossiers de ressources.

En fait, vous n'êtes pas obligé de tous les mettre dans /src/assets, vous pouvez les organiser et les utiliser en fonction de modules/composants. Par exemple, vous pouvez placer n'importe quel composant dans son propre répertoire et stocker des ressources statiques dans ce répertoire.

Règles d'introduction des ressources

Les chemins relatifs, tels que ./assets/logo.png seront analysés en dépendances de module. Ils seront remplacés par une URL générée automatiquement en fonction de la configuration de sortie de votre Webpack.

Un chemin sans préfixe, tel que assets/logo.png, est identique à un chemin relatif et est échappé vers ./assets/logo.png

Un chemin avec un préfixe ~. ~ est considéré comme une requête de module, de la même manière que require('some-module/image.png'). Chemin racine, tel que /assets/log.png

Obtenir le chemin de la ressource en JavaScript

computed: {
 background () {
  return require('./bgs/' + this.id + '.jpg')
 }
}
Copier après la connexion

Ce chemin de la ressource sera également traité par fichier -loader puis renvoie le chemin traité. Et Webpack chargera toutes les images du répertoire bgs en même temps.

Ressources statiques « réelles »

En revanche, aucun des fichiers en static/ ne sera traité par Webpack. Ils seront copiés directement dans le dossier cible et des chemins absolus doivent être utilisés pour référencer ces fichiers.

Recommandations associées :

Exemples de chargement de chemins de ressources statiques et de constantes dans thinkphp5

Tutoriel JavaScript sur le traitement des requêtes de fichiers de ressources statiques Méthode

10 articles recommandés sur les ressources statiques

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!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal