Simple usage example of vue recursive component

Simple usage example of vue recursive component

Preface

I believe many students are already familiar with recursion. We often use recursion to solve problems in algorithms. For example, the classic one is: from an array full of numbers, find the combination whose sum equals the target number. The idea is not difficult. Loop through the array to get values ​​and recursively add them until the target number conditions are met. Although recursion can solve most problems, its disadvantage is that it is easy to write code that results in an infinite loop and a stack overflow. Next, I will talk about the application of recursion in Vue components based on my actual business scenarios.

Use in Vue

To complete a complete recursion, I personally think there are two most important points:

  1. Determine the conditions for entering recursion;
  2. Determine the conditions for jumping out of the recursion;

The most important thing is to determine when to jump out of the recursion. The recursive component is actually very simple. It is just that component A calls component A again, which forms a recursion. Take the following business I encountered as an example. One day I received a requirement to filter out target users from a bunch of users based on different label conditions. Therefore, there is the following design diagram:

At first glance, you may be confused, but in fact, after careful analysis, you will find that it is not very difficult. Looking at the picture, many students will feel that it is a bit like what we often call nesting dolls, with one layer inside another. For this kind of graph, we first analyze which is the smallest unit. It is easy to see from the above figure that the smallest one is this one. The large structure in the figure is basically composed of this small piece. As long as this piece is implemented first, the rest is nothing more than rendering the data layer by layer through recursion.

The rest is nothing more than judging the data structure. If there is no subtree, simply render the item. If an item contains a subtree, you have to re-render the component and pass the child data into it. So the idea is actually very simple, assuming our data structure is like this:

{
 type: 'or',
 valueList: [
  {	
   condition: 'Number of logins in the last 7 days',
   login: '!=',
   value: 45
  },
  {	
   condition: 'Number of logins in the last 7 days',
   login: '!=',
   value: 45
  },
  {
   type: 'and'
   valueList: [
   	{
     condition: 'Number of logins in the last 7 days',
     login: '!=',
     value: 45
    }
   ]
  }
 ]
}

The data structure above is very clear. You can see that when the sub-item in the array contains valueList, it indicates that the small component mentioned in the above figure needs to be re-rendered. Therefore, we can simply code as follows (the following code can still be optimized):

<template>
 <div class="label-list">
  <el-tag type="primary" size="mini" class="logic">{{ typeDict[treedata.type] }}</el-tag>
  <template v-for="(item, index) in treedata.valueList">
   <ul v-if="!item.hasOwnProperty('valueList')" :key="'rule_' + index">
    <li>{{ item.condition }} {{ item.logic }} {{ item.value }}</li>
   </ul>
  </template>
  <template v-for="(item, index) in treedata.valueList">
   <!-- Here it is determined that there is a valuelist, so the rendering component is called again to render the sub-items-->
   <label-shows-view v-if="item.hasOwnProperty('valueList')" :key="'tree_' + index" :treedata="item"></label-shows-view>
  </template>
 </div>
</template>
<script>
const _TYPE = {
 'and': 'and',
 'or': 'or'
}
export default {
 name: 'LabelShowsView',
 props: {
  treedata: {
   type: Object,
   required: true
  }
 },
 data() {
  return {
   typeDict: _TYPE
  }
 }
}
</script>

It is not difficult to see that the main thing is to analyze and find the repeated parts in the data structure and render them layer by layer. In fact, the above example is relatively easy to understand for pure display purposes. If there is data interaction, extra attention needs to be paid. If the recursive level is very deep, event transmission and data changes need to be handled carefully. For example, when I completed the above visual configuration to filter customer groups, I encountered the following figure:

You can add and delete sub-items, and you can also drag each group to adjust its position. At this time, you can use a method similar to bubbling, where the child component triggers events and also receives events. For example, when deleting a set of conditions, you need to notify the parent component which item of child data to delete, as follows:

<!-- labelRulesView.vue -->
<!-- This custom component is the recursive component of this component-->
<label-rules-view v-if="item.hasOwnProperty('valueList')" :label-list="labelList" :treedata="item" :current-index="index" @delGroup="funDelGroup"></label-rules-view>
<!-- This component listens to the delGroup event -->
 
<el-button size="mini" type="danger" icon="el-icon-delete" class="operate-btn" @click="handleDelNewGroup(currentIndex)"></el-button>

// Delete a group handleDelNewGroup(index) {
 this.$emit('delGroup', index) // trigger events to upper-level components},
funDelGroup(index) {
 this.treedata.valueList.splice(index, 1)
},

In a recursive component, this component often plays the role of both a child component and a parent component. Therefore, it is necessary to control the interaction between data, otherwise it is easy to cause data confusion.

summary

This article is a record of what the author encountered in actual business scenarios. Using recursive components, we can even complete some more complex graphical displays. I hope this can help you broaden your thinking. If it helps you, please give me a little heart (I will definitely refuse next time [doge])

The above is the details of a simple usage example of the vue recursive component. For more information about the vue recursive component, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • In-depth understanding of Vue dynamic components and asynchronous components
  • Steps for Vue to use Ref to get components across levels
  • Vue implements multi-tab component
  • How are Vue components parsed and rendered?
  • Vue implements an Input component that gets the key display shortcut key effect
  • Example of communication between parent and child components of Vue (props, $ref, $emit)
  • Use of Vue mounted components
  • How does Vue reference other components (css and js)
  • Pop-up layer component of vue-dialog
  • Summary of Vue component basics

<<:  Sharing tips on using vue element and nuxt

>>:  Example code for implementing dynamic column filtering in vue+element table

Recommend

Tutorial on installing mysql8 on linux centos7

1. RPM version installation Check if there are ot...

Creation, constraints and deletion of foreign keys in MySQL

Preface After MySQL version 3.23.44, InnoDB engin...

About dynamically adding routes based on user permissions in Vue

Display different menu pages according to the use...

MySQL data archiving tool mysql_archiver detailed explanation

Table of contents I. Overview 2. pt-archiver main...

MySQL 8.0.15 installation and configuration method graphic tutorial

This article records the installation and configu...

Detailed tutorial on running selenium+chromedriver on the server

1. Introduction I want to use selenium to scrape ...

How to deploy MySQL 5.7 & 8.0 master-slave cluster using Docker

> Deploy MySQL 5.7 cluster master & slave ...

SSH port forwarding to achieve intranet penetration

The machines in our LAN can access the external n...

Detailed explanation of CSS elastic box flex-grow, flex-shrink, flex-basis

The functions of the three attributes flex-grow, ...

CSS perfectly solves the problem of front-end image deformation

I saw an article in Toutiao IT School that CSS pe...

iframe src assignment problem (server side)

I encountered this problem today. I reassigned the...

Detailed explanation of the difference between chown and chmod commands in Linux

In Linux system, both chmod and chown commands ca...

MySQL statement execution order and writing order example analysis

The complete syntax of the select statement is: S...

Detailed steps for installing nodejs environment and path configuration in Linux

There are two ways to install nodejs in linux. On...