首页 前端知识 (已解决)Vue routes的 children使用(小白来看,包会!)

(已解决)Vue routes的 children使用(小白来看,包会!)

2024-04-29 11:04:35 前端知识 前端哥 394 350 我要收藏

前言

分析链接:Vue+element ui实现好看的个人中心_vue个人信息页面代码-CSDN博客

使用了很多vue深层知识,简化并且做到自己的项目上面

对小白很有帮助,因为我就是小白,才搞明白。


最核心的就是routes的 children使用,所以先做一个例子再套用进去。

目录

前言

参考

1.项目结构

2.routes代码

3.IndextwoView代码

4.Page1View代码

5.pageSon代码

6.Page2View代码

routes解析:

1.简单常用段

2.重定向设置:

3.children的使用

3.1.导入

3.2.children的设置

页面逻辑解析

页面逻辑展示



参考

注:因为我是在自己项目做的测试,所以其他页面大家不需要也没关系,按逻辑去就行。

1.项目结构

2.routes代码

import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
import IndextwoView from "@/views/IndextwoView.vue"
const routes = [
{
path: '/IndextwoView',
name: 'IndextwoView',
component: IndextwoView,
children: [{
path: '/Page1View',
name: 'Page1View',
component: function () {
return import( /* webpackChunkName: "about" */ '@/views/Page1View.vue')
},
children: [{
path: '/pageSon',
name: 'pageSon',
component: function () {
return import( /* webpackChunkName: "about" */ '@/views/PageSon.vue')
}
}],
},
{
path: '/Page2View',
name: 'Page2View',
component: function () {
return import( /* webpackChunkName: "about" */ '@/views/Page2View.vue')
}
}]
},
{
//测试页面
path: '/test',
name: 'test',
component: () => import('../views/tlias/v-forTest.vue'),
},
{
//登录页面
path: '/login',
name: 'login',
component: () => import('../views/tlias/LoginView.vue'),
},
{
// 主页页面
path: '/index',
name: 'index',
component: () => import('../views/tlias/IndexView.vue'),
meta: { token: null }
},
{
// 后端页面
path: '/stu',
name: 'stu',
component: () => import('../views/tlias/StuView.vue')
},
{
// 后端页面
path: '/emp',
name: 'emp',
component: () => import('../views/tlias/EmpView.vue')
},
{
// 后端页面
path: '/dept',
name: 'dept',
component: () => import('../views/tlias/DeptView.vue')
},
{
path: '/',
redirect: '/login'
}
]
const router = new VueRouter({
routes
})
export default router
复制

3.IndextwoView代码

<template>
<div class="home">
<el-menu
default-active="2"
class="el-menu-vertical-demo"
>
<el-submenu index="1">
<template slot="title">
<i class="el-icon-location"></i>
<span slot="title"><router-link to="/Page1View">导航一</router-link></span>
</template>
</el-submenu>
<el-menu-item index="4">
<i class="el-icon-setting"></i>
<span slot="title"><router-link to="/Page2View">导航二</router-link></span>
</el-menu-item>
</el-menu>
<router-view></router-view>
</div>
</template>
复制

4.Page1View代码

<template>
<div class="pageone">page1
<router-link to="/pageSon">显示</router-link>
<router-view></router-view>
</div>
</template>
复制

5.pageSon代码

<template>
<div class="page1-son">page1-son</div>
</template>
复制

6.Page2View代码

<template>
<div class="page2">page2</div>
</template>
复制

routes解析:

1.简单常用段

下面的代码为基础路由就带有的功能带了几个页面逻辑很简单易懂,所以不解释。

import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
const routes = [
{
//测试页面
path: '/test',
name: 'test',
component: () => import('../views/tlias/v-forTest.vue'),
},
{
//登录页面
path: '/login',
name: 'login',
component: () => import('../views/tlias/LoginView.vue'),
},
{
// 主页页面
path: '/index',
name: 'index',
component: () => import('../views/tlias/IndexView.vue'),
meta: { token: null }
},
{
// 后端页面
path: '/stu',
name: 'stu',
component: () => import('../views/tlias/StuView.vue')
},
{
// 后端页面
path: '/emp',
name: 'emp',
component: () => import('../views/tlias/EmpView.vue')
},
{
// 后端页面
path: '/dept',
name: 'dept',
component: () => import('../views/tlias/DeptView.vue')
},
]
const router = new VueRouter({
routes
})
export default router
复制

2.重定向设置:

由于路由中默认的为访问/路径,所以我们需要使用关键字redirect设置重定向,使他访问/路径时,访问到/login路径

{
path: '/',
redirect: '/login'
}
复制

3.children的使用

3.1.导入


在使用时需要导入主界面

import IndextwoView from "@/views/IndextwoView.vue"
复制

3.2.children的设置

最上层的为导入的主页面的路径以及设置

后面就可以设置内部的子路由:

注:子路由中的: component: function () {
        return import( /* webpackChunkName: "about" */ '@/views/Page1View.vue')
      },为过时写法,可以转换成 component: () => import('../views/tlias/LoginView.vue'),
也是可以使用的,没有区别

{
path: '/IndextwoView',
name: 'IndextwoView',
component: IndextwoView,
children: [{
path: '/Page1View',
name: 'Page1View',
component: function () {
return import( /* webpackChunkName: "about" */ '@/views/Page1View.vue')
},
children: [{
path: '/pageSon',
name: 'pageSon',
component: function () {
return import( /* webpackChunkName: "about" */ '@/views/PageSon.vue')
}
}],
},
{
path: '/Page2View',
name: 'Page2View',
component: function () {
return import( /* webpackChunkName: "about" */ '@/views/Page2View.vue')
}
}]
},
复制

页面逻辑解析

在主页面中使用

<router-link to="/Page2View">
复制

进行路由跳转

然后使用

<router-view></router-view>
复制

进行页面渲染

以便于children的生效


页面逻辑展示

1.首先是我自己的页面登录(因为重定向为login)

2.进入后点击个人中心(接下来到例子内容

3.点击导航一(成功显示内容)

4.点击显示(成功显示page1-son)

5.点击导航二(成功清除原来组件,并显示page2)


套用原个人中心代码

更新中...

转载请注明出处或者链接地址:https://www.qianduange.cn//article/5998.html
标签
评论
发布的文章

JQuery中的load()、$

2024-05-10 08:05:15

大家推荐的文章
会员中心 联系我 留言建议 回顶部
复制成功!