Steps for Vue to use Ref to get components across levels

Steps for Vue to use Ref to get components across levels

Vue uses Ref to get component instances across levels

Example Introduction

During the development process, we will inevitably use cross-level ref instance acquisition. In most cases, we can find the required instance through the component's own parent or children . However, when the hierarchy is unclear or too deep, this method is inevitably cumbersome and inefficient.

As shown in the figure below, we use組件E to obtain the component instance of組件D

Document directory structure

There are six components, namely A, B, C, D, E and index, and they are inserted into their respective pages in the order of the components in the above figure.

The page style is as follows:

Install vue-ref

Download vue-ref

npm install vue-ref --save

Global Registration

import ref from 'vue-ref'
Vue.use(ref)

How to use

<!-- vm.dom will be the DOM node -->
<p v-ref="c => this.dom = c">hello</p>

<!-- vm.child will be the child component instance -->
<child-component v-ref="c => this.child = c"></child-component>

<span v-for="n in 10" :key="n" v-ref="(c, key) => {...}">{{ n }} </span>

Root component custom method [using provide and inject]

In our index page, we provide three methods:

  • Set the instance of the child component, setChildrenRef
  • Get from component instance, getChildrenRef
  • Get the current node instance, getRef
provide() {
  return {
   setChildrenRef: (name, ref) => {
    this[name] = ref
   },
   getChildrenRef: name => {
    return this[name]
   },
   getRef: () => {
    return this
   }
  }
 },

Describe each page separately

Component A page:

Get the setChildrenRef method through the injection method, and cache component D through the above instructions

Component B page:

Component C page:

Component D page:

Component E page:

In this page, we not only inject two methods, but also set a method to switch the color of component D to test whether we have really obtained the instance of component D across levels.

result

As you can see, the three parent instances are the same, and the text style of component D is successfully modified in component E. good!

The above is the details of the steps for Vue to use Ref to obtain components across levels. For more information about Vue using Ref to obtain components, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • In-depth explanation of Vue multi-select list component
  • Problems and solutions encountered when using v-model to two-way bind the values ​​of parent-child components in Vue
  • Vue example code using transition component animation effect
  • Summary of Vue component basics
  • In-depth understanding of Vue dynamic components and asynchronous components
  • Vue implements multi-tab component
  • Easily implement the whole process of switch function components in vue3
  • How to customize dialog and modal components in Vue3
  • Correct way to force component to re-render in Vue
  • Two ways to dynamically create components in Vue
  • Detailed explanation of incompatible changes of components in vue3

<<:  Installation tutorial of the latest stable version of MySQL 5.7.17 under Linux

>>:  mysql5.7 create user authorization delete user revoke authorization

Recommend

A brief discussion on the semantics of HTML and some simple optimizations

1. What is semanticization? Explanation of Bing D...

Node.js+postman to simulate HTTP server and client interaction

Table of contents 1. Node builds HTTP server 2. H...

Solve the problem of blocking positioning DDL in MySQL 5.7

In the previous article "MySQL table structu...

MySQL 8.0.23 installation super detailed tutorial

Table of contents Preface 1. Download MySQL from ...

Understanding Nginx Current Limitation in One Article (Simple Implementation)

Nginx is now one of the most popular load balance...

Analysis of two implementation methods for adding static routing in Linux

Command to add a route: 1.Route add route add -ne...

Detailed explanation of MySQL master-slave database construction method

This article describes how to build a MySQL maste...

Small program to implement a simple calculator

This article example shares the specific code of ...

When backing up files in Centos7, add the backup date to the backup file

Linux uses files as the basis to manage the devic...

10 skills that make front-end developers worth millions

The skills that front-end developers need to mast...

The most commonly used HTML tags to create web pages

1. Optimization of commonly used HTML tags HTML s...