Nested display implementation of vue router-view

Nested display implementation of vue router-view

1. Routing Configuration

const routes = [
  {
    path: '/',
    name: 'Navigation 1',
    component: Home,
    children:[
      {
        path: '/customer',
        name: 'Customer',
        // route level code-splitting
        // this generates a separate chunk (about.[hash].js) for this route
        // which is lazy-loaded when the route is visited.
        component: () => import(/* webpackChunkName: "about" */ '../views/Customer.vue')
      },
      {
        path: '/pageOne',
        name: 'Page 1',
        component: PageOne,

      },
      {
        path: '/pageTwo',
        name: 'Page 2',
        component: PageTwo,
    },
    ]
  },
  {
    path: '/navigation',
    name: 'Navigation 2',
    component: Home,
    children:[
      {
        path: '/pageThree',
        name: 'Page 3',
        component: PageThree,

      },
      {
        path: '/pageFour',
        name: 'Page 4',
        component: PageFour
      },
    ]
  },

2. Vue page nesting

App.vue first configures the first router-view

// An highlighted block
 <router-view></router-view>

Home.vue configures the second router-view

// An highlighted block
<template>
  <div>
  <el-container style="height: 500px; border: 1px solid #eee">
    <el-aside width="200px" style="background-color: rgb(238, 241, 246)">

      <el-menu>
        <el-submenu v-for="(item,index) in $router.options.routes" :index="index+''">
        <template slot="title"><i class="el-icon-sell"></i>{{item.name}}</template>
          <el-menu-item v-for="(item2,index2) in item.children" :index="index+'-'+index2">{{item2.name}}</el-menu-item>
        </el-submenu>
      </el-menu>
    </el-aside>

    <el-container>
      <el-header style="text-align: right; font-size: 12px">
        <el-dropdown>
          <i class="el-icon-setting" style="margin-right: 15px"></i>
          <el-dropdown-menu slot="dropdown">
            <el-dropdown-item>View</el-dropdown-item>
            <el-dropdown-item>New</el-dropdown-item>
            <el-dropdown-item>Delete</el-dropdown-item>
          </el-dropdown-menu>
        </el-dropdown>
        <span>Wang Xiaohu</span>
      </el-header>

      <el-main>
        <router-view></router-view>

      </el-main>
    </el-container>

  </el-container>

</div>
</template>

<style>
.el-header {
  background-color: #B3C0D1;
  color: #333;
  line-height: 60px;
}

.el-aside {
  color: #333;
}
</style>

<script>
export default {

};
</script>

3. Nested Relationships

First, when you visit http://localhost:8181/, you will enter the first level of nesting, and then enter the first router-view: Home.vue. Then when pageone is accessed, Home.vue will be accessed as well.

Because the nested display of router-view is related to the nested routing path, you can see that in the routing, under the path of navigation one are the routing paths of page one and page two respectively. So when accessing page one, the parent path Home.vue page will be accessed first. If you add Home.vue page without placing router-view, the lower-level pages will not be displayed

This is the end of this article about the nested display implementation of vue router-view. For more related vue router-view nested display content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • The implementation principle of Vue router-view and router-link
  • Solve the problem that the content of the reused component of vue update router-view does not refresh
  • Tutorial on using router-view component in vue
  • Vue2 sets the default path of router-view
  • Vue implements the method of having multiple router-views on the same page
  • Solution to vue2.0 routing not displaying router-view
  • Solution to router-view not rendering in vue-router
  • Implementation of nested jump of vue routing view router-view

<<:  Use Python to connect to MySQL database using the pymysql module

>>:  Install JDK8 in rpm mode on CentOS7

Recommend

Linux loading vmlinux debugging

Loading kernel symbols using gdb arm-eabi-gdb out...

A brief discussion on using virtual lists to optimize tables in el-table

Table of contents Preface Solution Specific imple...

Use of MySQL truncate table statement

The Truncate table statement is used to delete/tr...

MySQL index leftmost principle example code

Preface I was recently reading about MySQL indexe...

Summary of examples of common methods of JavaScript arrays

Table of contents Common array methods concat() M...

A time-consuming troubleshooting process record of a docker error

Table of contents origin Environmental Informatio...

HTML tag default style arrangement

html, address,blockquote,body, dd, div,dl, dt, fie...

Steps to purchase a cloud server and install the Pagoda Panel on Alibaba Cloud

Alibaba Cloud purchases servers Purchase a cloud ...

Solution to ElementUI's this.$notify.close() call not working

Table of contents Requirement Description Problem...

An example of elegant writing of judgment in JavaScript

Table of contents Preface 1. Monadic Judgment 1.1...

Several mistakes that JavaScript beginners often make

Table of contents Preface Confusing undefined and...

SSH port forwarding to achieve intranet penetration

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

jQuery implements simple pop-up window effect

This article shares the specific code of jQuery t...