Welche Methoden gibt es für Referenzpfade in Vue-Einzeldateien?
Dieser Artikel führt Sie hauptsächlich in die relevanten Informationen zur Referenzpfadverarbeitung in einer einzelnen Vue-Datei ein. Der Artikel stellt sie ausführlich anhand von Beispielcode vor. Es hat einen gewissen Referenz-Lernwert, damit jeder vue.js lernen oder verwenden kann. Freunde, die es brauchen. Lasst uns gemeinsam mit mir lernen.
Vorwort
Vues Einzeldateikomponente wird sehr häufig bei der Verwendung von Vue und im Entwicklungsprozess von Vue-Einzeldateien in Einzeldateien verwendet Datei Die Vorlage kann die Verarbeitung von Dateipfaden wie , die Verarbeitung von Hintergrundstilen usw. umfassen. Im Folgenden wird die SRC-Verarbeitung von
in verschiedenen Szenarien erläutert und erläutert, wie statische Ressourcen (z. B. Bildverarbeitung) während des Entwicklungsprozesses mithilfe von vue+webpack korrekt referenziert werden.
Wie unten gezeigt, sind Beispiele für die Referenzierung von Bildpfaden in verschiedenen Szenarien in der einzelnen Dateikomponente unten angegeben (statische Bildressourcen werden in src/assets/small.png gespeichert):
<template> <p id="app"> <!-- 1. 模版中src选项直接写相对路径 --> <img src="./assets/small.png" alt="图片相对路径测试"> <!-- 2. 模版中src选项绑定相对路径字符串 --> <img :src="relative_img" alt="图片相对路径测试"> <!-- 3. 模版中src选项绑定html绝对路径字符串 --> <img :src="absolute_img" alt="图片绝对路径测试"> <!-- 4. 模版中src选项绑定手动加载的图片资源 --> <img :src="smallImg" alt="图片资源测试"> </p> </template> <script> import smallImg from './assets/small.png'; export default { name: 'app', data() { return { smallImg: smallImg, relative_img: './assets/small.png', absolute_img: '/static/img/small.png', }; }, } </script>
Die Die obigen Codeausschnitte zeigen, wie das img-Tag verwendet wird, um in vier Szenarien auf Bildressourcen in der Vue-Einzeldateikomponente zu verweisen. Natürlich können nicht alle dieser vier Methoden Bildressourcen korrekt laden.
Fall 1:
ist direkt an das src-Attribut mit einem relativen Pfad in der Vorlage gebunden. In diesem Fall kann die Bildressource korrekt geladen werden. Wir wissen, dass der Vue-Loader bei der Webpack-Verarbeitung einzelner Vue-Dateikomponenten hauptsächlich für die Verarbeitung von *.vue-Dateien verantwortlich ist. Im Abschnitt zur Vue-Loader-Ressourcenpfadverarbeitung in der Vue-Loader-Dokumentation wird erläutert, wie Vue-Loader Ressourcenpfade in Vorlagen verarbeitet. Zum Beispiel: , Hintergrund: url(), @import usw. werden als Modulabhängigkeiten verarbeitet. Das heißt, in diesen Fällen verarbeitet der Vue-Loader automatisch die Ressourcenreferenz des Pfads und die endgültige Pfadersetzung. Die Verarbeitung von img ist wie folgt:
<img src="./logo.png">
wird vom Vue-Template-Compiler kompiliert in:
createElement('img', { attrs: { src: require('./logo.png') }})
Dies erklärt auch, warum der Bildinhalt in Fall 1 korrekt angezeigt werden kann, da vue- Loader Hilft uns automatisch bei der Ressourceneinführung und Pfadersetzung.
Fall 2:
Die relative Pfad-String-Variable ist an das src-Attribut in der Vorlage gebunden. In diesem Fall kann das Bild nicht sein normal angezeigt. Der Grund dafür ist, dass der Vue-Loader nicht erkennen kann, ob es sich bei der Variablen um eine Pfadzeichenfolge handelt. Daher besteht kein Problem, dass der Vue-Loader automatisch Ressourcen einführt und den Pfad ersetzt. In diesem Fall ist die kompilierte Vorlage immer noch eine relative Pfadzeichenfolge. Offensichtlich kann das Bild ohne die entsprechende Ressourceneinführung und den falschen Pfad nicht korrekt angezeigt werden.
Situation 3:
Viele Leute versuchen, die Einführung absoluter Pfadvariablen zu verwenden, wenn der relative Pfad nicht korrekt angezeigt werden kann In diesem Fall kann das Bild nicht angezeigt werden, da die Bildressource nicht manuell eingegeben wurde. Hinweis: Viele Schüler versuchen, Ressourcen manuell einzuführen und src dann entsprechend der absoluten Pfadvariablen zu binden. Sie stellen fest, dass es tatsächlich referenzierte Ressourcen unter dem Pfad dist/static/img/ gibt, aber der URL-Loader in der vue-cli-Webpack-Vorlage Funktioniert nicht für Dateien vom Typ IMG. Beim Laden wird die Verarbeitung von Hashwerten hinzugefügt. Selbst wenn wir in diesem Fall eine absolute Pfadvariable binden, können wir das Bild immer noch nicht korrekt referenzieren, da es nicht korrekt mit der Bilddatei übereinstimmen kann, zu der der Hashwert hinzugefügt wird. In diesem Fall, in dem Bilder manuell eingefügt werden müssen, wird die Vorgehensweise zu Situation 4 empfohlen.
Fall 4:
Das src-Attribut in der Vorlage ist direkt an die manuell eingegebene Bildressource gebunden korrekt angezeigt werden. Diese Methode wird auch vom Vue-Loader verwendet, wenn Ressourcen verarbeitet werden, die automatisch importierten Pfaden entsprechen.
Zusammenfassend lässt sich sagen, dass in der Vue-Einzeldateikomponente der Schlüssel zur korrekten Anzeige eines Bildes wie folgt lautet:
Wenn die Bildressource erforderlich oder importiert ist, wird dies der Fall sein Wird vom URL-Loader des Webpacks verwendet und in das endgültige Verzeichnis verarbeitet.
Das img src-Attribut muss durch den endgültigen Bildressourcenpfad ersetzt werden
Die beiden oben genannten Punkte sind unverzichtbar. Der Grund dafür, dass das Bild im ersten und vierten Fall korrekt angezeigt werden kann, liegt darin, dass die beiden oben genannten Bedingungen in beiden Fällen erfüllt sind. Im ersten Fall erledigt der Vue-Loader dies automatisch für uns, und im vierten Fall erledigen wir es manuell.
Probleme, die während der Entwicklung auftreten können:
Während der Entwicklung kann es zu einem Szenario kommen, in dem eine Liste von Bildern in einer Schleife gerendert wird . Gemäß der obigen Zusammenfassung können wir ein Array von Bildinformationsobjekten erstellen, wie zum Beispiel:
<template> <p id="app"> <!-- 1. 模版中 src 选项直接写相对路径 --> <img src="./assets/small.png" alt="图片相对路径测试"> <!-- 2. 模版中 src 选项绑定相对路径字符串 --> <img :src="relative_img" alt="图片相对路径测试"> <!-- 3. 模版中 src 选项绑定绝对路径字符串 --> <img :src="absolute_img" alt="图片绝对路径测试"> <!-- 4. 模版中 src 选项绑定手动加载的图片资源 --> <img :src="smallImg" alt="图片测试"> <!-- 5. 循环加载图片资源示例 --> <img v-for="image in imgList" :key="image.id" :src="image.src" :alt="image.title"> </p> </template> <script> import smallImg from './assets/small.png'; import bigImg from './assets/big.jpg'; export default { name: 'app', data() { return { smallImg: smallImg, relative_img: './assets/small.png', absolute_img: '/static/img/small.png', imgList: [ { id: 1, title: 'test1', src: require('./assets/logo1.png') }, { id: 2, title: 'test2', src: require('./assets/logo2.png') }, { id: 3, title: 'test3', src: require('./assets/logo3.png') }, ], }; }, } </script>
, damit wir die von uns gerenderten Bilder perfekt in einer Schleife anzeigen können.
Ich habe das Obige für Sie zusammengestellt und hoffe, dass es Ihnen in Zukunft hilfreich sein wird.
Verwandte Artikel:
Verwenden des Eingabefelds zum Suchen von Schlüsselwörtern in jquery
Wie ändert man den Skin in Vue?
So implementieren Sie die angegebene Zuweisungsmethode mit js und jQuery
Das obige ist der detaillierte Inhalt vonWelche Methoden gibt es für Referenzpfade in Vue-Einzeldateien?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Es gibt drei Möglichkeiten, sich auf JS -Dateien in Vue.js zu beziehen: Geben Sie den Pfad direkt mit dem & lt; Skript & gt an. Etikett;; Dynamischer Import mit dem montierten () Lebenszyklushaken; und importieren über die Vuex State Management Library.

Mit der Watch -Option in Vue.js können Entwickler auf Änderungen in bestimmten Daten anhören. Wenn sich die Daten ändert, löst sich eine Rückruffunktion aus, um Aktualisierungsansichten oder andere Aufgaben auszuführen. Zu den Konfigurationsoptionen gehören unmittelbar, die festlegen, ob ein Rückruf sofort ausgeführt werden soll, und Deep, das feststellt, ob Änderungen an Objekten oder Arrays rekursiv anhören sollen.

Die Verwendung von Bootstrap in Vue.js ist in fünf Schritte unterteilt: Startstrap installieren. Bootstrap in main.js. Verwenden Sie die Bootstrap -Komponente direkt in der Vorlage. Optional: benutzerdefinierter Stil. Optional: Verwenden Sie Plug-Ins.

Sie können der VUE -Taste eine Funktion hinzufügen, indem Sie die Taste in der HTML -Vorlage an eine Methode binden. Definieren Sie die Methode und schreiben Sie die Funktionslogik in der VUE -Instanz.

Implementieren Sie Marquee/Text-Scrolling-Effekte in VUE unter Verwendung von CSS-Animationen oder Bibliotheken von Drittanbietern. In diesem Artikel wird die Verwendung von CSS -Animation vorgestellt: Bildlauftext erstellen und Text mit & lt; div & gt;. Definieren Sie CSS -Animationen und setzen Sie Überlauf: Versteckt, Breite und Animation. Definieren Sie Keyframes, setzen Sie Transformation: Translatex () am Anfang und am Ende der Animation. Passen Sie die Animationseigenschaften wie Dauer, Bildlaufgeschwindigkeit und Richtung an.

In Vue.js können Komponenten oder Ressourcen bei Bedarf dynamisch geladen werden, wodurch die Ladezeit der Anfangsseite dynamisch geladen und die Leistung verbessert wird. Die spezifische Implementierungsmethode umfasst die Verwendung & lt; Keep-Alive & GT; und & lt; Komponente ist & gt; Komponenten. Es ist zu beachten, dass fauler Laden FOUC -Probleme (Splace Screen) verursachen kann und nur für Komponenten verwendet werden sollte, die eine faule Belastung erfordern, um unnötige Leistungsaufwand zu vermeiden.

VUE.JS hat vier Methoden, um zur vorherigen Seite zurückzukehren: $ router.go (-1) $ router.back () verwendet & lt; Router-Link to = & quot;/& quot; Komponentenfenster.history.back () und die Methodenauswahl hängt von der Szene ab.

Sie können die Vue -Version mit Vue Devtools abfragen, um die Registerkarte VUE in der Konsole des Browsers anzuzeigen. Verwenden Sie NPM, um den Befehl "npm list -g vue" auszuführen. Suchen Sie das Vue -Element im Objekt "Abhängigkeiten" der Datei package.json. Führen Sie für Vue -CLI -Projekte den Befehl "Vue --version" aus. Überprüfen Sie die Versionsinformationen im & lt; Skript & gt; Tag in der HTML -Datei, die sich auf die VUE -Datei bezieht.
