Maison >interface Web >uni-app >Comment résoudre le problème selon lequel les composants personnalisés Uniapp ne s'affichent pas après avoir été empaquetés

Comment résoudre le problème selon lequel les composants personnalisés Uniapp ne s'affichent pas après avoir été empaquetés

PHPz
PHPzoriginal
2023-04-14 13:33:523290parcourir

Avec l'évolution rapide de la technologie de développement front-end, de plus en plus de développeurs choisissent d'utiliser le framework uniapp pour le développement multi-end. Cependant, lors de l'utilisation de composants personnalisés Uniapp, nous rencontrons parfois le problème que les composants ne s'affichent pas après l'emballage. Examinons ensuite de plus près la solution au problème selon lequel les composants personnalisés d'uniapp ne s'affichent pas après avoir été empaquetés.

Avant de commencer à résoudre le problème, vous devez comprendre le processus d'emballage des composants personnalisés uniapp. Lorsque vous utilisez uniapp pour écrire un composant personnalisé, nous devons écrire la logique du composant dans le fichier vue du composant, utiliser l'instruction export default pour exporter et enregistrer le composant actuel lors de l'exportation du composant, et enfin introduire le composant dans le vue qui doit utiliser le composant. Ce processus peut impliquer des feuilles de style de composants, des modèles, etc.

Lorsque nous utilisons npm run build ou emballons le projet uniapp dans HBuilderX, nous emballons en fait tout le code source du projet en cours dans un fichier de ressources statiques et générons le fichier manifest.json correspondant. Enfin, le fichier de ressources empaqueté et le manifeste sont. Les fichiers .json sont placés ensemble dans le répertoire dist. Ces fichiers packagés sont les fichiers que nous devons finalement déployer sur le serveur.

Lorsque nous introduisons le composant personnalisé uniapp dans la page Web, un composant Vue est en fait généré dynamiquement via JS, et le composant généré est inséré dans le DOM du fichier vue actuel en tant que sous-composant. Lors de l'empaquetage d'uniapp, l'outil d'empaquetage extraira toutes les ressources statiques introduites par le projet en cours (y compris les feuilles de style des composants, les modèles, la logique JS, etc.) et les empaquetera dans un fichier .css.js文件,然后在index.html文件中通过link或script标签引入这些文件。这些生成的.css.js indépendant, ce dont nous avons besoin lors de l'utilisation de composants personnalisés. Fichiers importés.

Cependant, dans certains cas, nous avons constaté que les composants emballés ne s'affichaient pas correctement. Ceci est généralement dû aux raisons suivantes :

  1. La feuille de style du composant n'est pas packagée correctement

Dans les composants personnalisés, nous utilisons parfois l'instruction import pour introduire les feuilles de style de certaines bibliothèques de composants tiers et les appliquer à dans le composant actuel. Cependant, après l'empaquetage, ces feuilles de style importées peuvent ne pas être correctement empaquetées dans la feuille de style finale du composant Uniapp en raison de problèmes de chemin. À ce stade, nous devons vérifier si le fichier de feuille de style du composant existe dans le fichier composant.css fourni.

  1. Le nom du composant n'est pas nommé selon la spécification

Dans uniapp, chaque composant doit avoir un nom unique. Le nom est séparé par des lettres minuscules et des traits de soulignement, tels que « composant personnalisé », et le nom doit être globalement unique. Si le nom du composant n'est pas nommé conformément à la spécification, le composant peut ne pas être affiché après l'emballage. À ce stade, nous devons vérifier si le nom du composant est conforme à la convention de dénomination et s'il entre en conflit avec d'autres noms de composants.

  1. Le modèle ou la balise de script du composant n'est pas analysé correctement

Lorsque nous utilisons une syntaxe ou un style de codage spécial pendant le processus de développement, le modèle ou la balise de script du composant packagé peut ne pas être analysé correctement. Par exemple, si vous utilisez une syntaxe telle que la boucle v-for dans vue, vous devez également utiliser un format de syntaxe spécial dans uniapp. S'il n'est pas écrit conformément aux spécifications, le composant risque de ne pas s'afficher correctement après l'emballage. À ce stade, nous devons vérifier si les balises de modèle et de script du composant sont conformes aux spécifications de syntaxe d'uniapp.

  1. Le composant ne s'exporte pas correctement

Enfin, l'export du composant est également un problème qui peut entraîner le non-affichage du composant. Si le composant que nous exportons n'est pas correctement enregistré dans le composant global d'uniapp conformément à la spécification, cela peut entraîner un affichage incorrect du composant. À ce stade, nous devons vérifier si le composant est exporté correctement et s'il est enregistré globalement.

Pour résumer, les quatre situations ci-dessus sont toutes des raisons possibles pour lesquelles les composants personnalisés uniapp ne peuvent pas être affichés normalement après avoir été empaquetés. Lorsque nous utilisons des composants personnalisés, nous devons prêter attention aux problèmes ci-dessus et les écrire et les empaqueter conformément aux spécifications d'uniapp. Ce n'est qu'ainsi que nous pourrons garantir que les composants personnalisés peuvent être utilisés normalement dans uniapp.

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:
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