Heim > Web-Frontend > View.js > So verwenden Sie $refs für den Zugriff auf Komponenten und HTML-Elemente in Vue

So verwenden Sie $refs für den Zugriff auf Komponenten und HTML-Elemente in Vue

WBOY
Freigeben: 2023-06-11 14:59:02
Original
1557 Leute haben es durchsucht

$refs in Vue ist eine sehr praktische Funktion, die uns den Zugriff auf Komponenten und HTML-Elemente in einer Vue-Instanz ermöglicht. Diese Funktion ermöglicht uns den direkten Zugriff auf DOM-Elemente in Vorlagen, berechneten Eigenschaften, Methoden und Lebenszyklus-Hooks und kann das Schreiben von Code vereinfachen. In diesem Artikel wird erläutert, wie Sie mit $refs auf Komponenten und HTML-Elemente in Vue zugreifen.

1. Auf Komponenten zugreifen

In Vue sind Komponenten wichtige Module. Wir werden viele Komponenten im Projekt verwenden, daher ist der Zugriff auf Komponenten erforderlich. Wie können wir also $refs verwenden, um auf Komponenten zuzugreifen?

In Vue können wir ein Ref-Attribut für die Komponente festlegen. In Vorlagen oder JS können wir $refs verwenden, um auf diese Komponente zuzugreifen.

Schreiben wir ein Beispiel:

<script><br>import ChildComponent from './ChildComponent.vue' </p> <p>export default {<br> Components: {</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>ChildComponent</pre><div class="contentsignin">Nach dem Login kopieren</div></div><p>},<br> Mounted() {</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>this.$refs.myComponent.doSomething()</pre><div class="contentsignin">Nach dem Login kopieren</div></div><p>}<br>}<br></script>

In diesem Beispiel haben wir auf eine untergeordnete Komponente in der untergeordneten Komponente der übergeordneten Komponente verwiesen und eine hinzugefügt ref-Attribut für den Zugriff. Im gemounteten Lebenszyklus-Hook können wir auf diese Komponente zugreifen und die doSomething-Methode dieser Komponente aufrufen.

Kurz gesagt, es ist sehr praktisch, $refs für den Zugriff auf Komponenten zu verwenden. Wir können es direkt für Zugriffsvorgänge verwenden.

2. Auf HTML-Elemente zugreifen

Es ist auch sehr einfach, $refs für den Zugriff auf HTML-Elemente zu verwenden. Wir können auch ein Ref-Attribut für ein Element festlegen und dann $refs verwenden, um in JS auf dieses Element zuzugreifen. Schreiben wir ein Beispiel:

<script><br>export default {<br> Mounted() {</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>this.$refs.myInput.focus()</pre><div class="contentsignin">Nach dem Login kopieren</div></div><p>} <br> }<br></script>

In diesem Beispiel fügen wir dem Eingabeelement ein Ref-Attribut für den Zugriff hinzu. Im gemounteten Lebenszyklus-Hook rufen wir die Methode focus() auf, um das Eingabeelement zum Fokus zu machen.

Ebenso ist es auch sehr praktisch, $refs für den Zugriff auf HTML-Elemente zu verwenden. Wir können das Ref-Attribut direkt zum Element in der Vorlage hinzufügen, um Zugriffsvorgänge auszuführen.

3. Was Sie beachten sollten

In Vue ist es sehr praktisch, $refs für den Zugriff auf Komponenten und HTML-Elemente zu verwenden, aber es muss mit Vorsicht verwendet werden. Die Komponenten und Elemente, auf die $refs zugreift, müssen gerendert worden sein. Wenn Sie auf ein Element oder eine Komponente zugreifen, bevor Sie es mounten, werden Sie undefiniert.

Wenn wir in einer Vue-Komponente asynchrone Vorgänge ausführen oder Daten manipulieren, ändert sich der Lebenszyklus-Hook dieser Komponente. Diese Änderung kann dazu führen, dass $refs undefiniert zurückgibt. Seien Sie daher bei der Verwendung von $refs vorsichtig und stellen Sie sicher, dass beim Zugriff auf ein Element oder eine Komponente dieses gerendert wurde.

Gleichzeitig müssen wir auch auf die Benennung der Komponenten achten, um ihre Einzigartigkeit sicherzustellen. Denn wenn über $refs auf eine Komponente zugegriffen wird, erfolgt der Zugriff über den Namen. Wenn mehrere Komponenten mit demselben Namen vorhanden sind, wird möglicherweise auf falsche Komponenten zugegriffen.

4. Zusammenfassung

In Vue ist es sehr praktisch, $refs für den Zugriff auf Komponenten und HTML-Elemente zu verwenden. Fügen Sie der Komponente oder dem Element einfach ein Ref-Attribut hinzu und Sie können in JS darauf zugreifen. Wir müssen jedoch darauf achten, dass die von $refs zurückgegebene Komponente oder das zurückgegebene Element bereits gerendert wurde, und wir müssen auf die Benennung der Komponente achten, um ihre Einzigartigkeit sicherzustellen.

In der tatsächlichen Entwicklung können wir $refs in Verbindung mit v-if, v-for und anderen Anweisungen verwenden, um das Projekt besser abzuschließen. Achten Sie bei der Verwendung von $refs natürlich darauf, es nicht zu häufig zu verwenden, und vermeiden Sie es, die Daten in der untergeordneten Komponente direkt in der übergeordneten Komponente zu ändern, da dies das Prinzip des unidirektionalen Datenflusses zerstören würde.

Das obige ist der detaillierte Inhalt vonSo verwenden Sie $refs für den Zugriff auf Komponenten und HTML-Elemente in Vue. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage