路由的使用

路由的使用

路由重定向

redirect

javascript 复制代码
 {
        path: '/',
        // 通过这种方式,在访问/路径的时候会重定向到/login路径
        redirect: '/login'
    },
路由高亮

router-link-active

自定义 linkActiveClass

javascript 复制代码
//APP.vue
<style>
.router-link-active {
  background-color: aquamarine;
  font-size: 20px;
}

.my-active {
  background-color: aquamarine;
  font-size: 20px;
}
</style>

//src/router/index.js
const router = new VueRouter({
    mode: 'history',
    base: process.env.BASE_URL,
    routes,
    linkActiveClass:'my-active'
})

路由嵌套 ⻚面布局

  • 在路由里面加一个children属性,是一个数组,数组里面是路由对象, path里面不加'/',
  • 在嵌套的父组件里面加上router-view标签
javascript 复制代码
import Vue from 'vue'
import VueRouter from 'vue-router'
import ParentComp from '@/views/ParentComp.vue'
import login from '@/components/login.vue'
import registry from '@/components/registry.vue'

Vue.use(VueRouter)

const routes = [
    {
        path: '/',
        // 通过这种方式,在访问/路径的时候会重定向到/login路径
        redirect: '/parent'
    },
    {
        path: '/parent',
        component: ParentComp,
        // 涉及到了子路由的内容
        children: [
            {
                // 这就是用相对路径,相对于父组件的,这个实际路径就是/parent/login
                path: 'login',
                component: login
            },
            {
                // 这就是用相对路径,相对于父组件的,这个实际路径就是/parent/login
                path: 'registry',
                component: registry
            }
        ]
    }
]

const router = new VueRouter({
    mode: 'history',
    base: process.env.BASE_URL,
    linkActiveClass: 'my-active',
    routes
})

export default router
命名视图
  • 一个路径可以对应多个组件 属性components
javascript 复制代码
//APP.vue
<template>
  <!-- 通过这个路由的嵌套,我们可以实现一些布局 -->
  <div id="app">
    <!-- router-view可以设置名字,指定渲染的组件 -->
    <router-view></router-view>
    <div class='my-container'>
      <router-view name='sidebar'></router-view>
      <router-view name='main'></router-view>
    </div>
  </div>
</template>
<style>
  .router-link-active {
      background-color: aquamarine;
      font-size: 20px;
    }

    .my-active {
      background-color: aquamarine;
      font-size: 20px;
    }

    .header {
      width: 100%;
      height: 80px;
      background-color: red;
    }

    .my-container {
      height: calc(100vh - 80px);
    }

    .sidebar {
      height: 100%;
      float: left;
      width: 200px;
      background-color: gray;
    }

    .main {
      height: 100%;
      margin-left: 200px;
      background-color: khaki;
    }
</style>
javascript 复制代码
//src/router/index.js
import Vue from 'vue'
import VueRouter from 'vue-router'
import HeaderModel from '@/components/HeaderModel.vue'
import SidebarModel from '@/components/SidebarModel.vue'
import MainModel from '@/components/MainModel.vue'
// import TestModel from '@/components/TestModel.vue'

Vue.use(VueRouter)

const routes = [
  {
    path: '/',
    // 使用 components 可以定义多个组件
    components: {
      // 通过default属性可以设置默认的组件,默认组件只有一个,不写名字也可以渲染
      default: HeaderModel,
      sidebar: SidebarModel,
      MainModel
    },
    // children: [
    //     { path: 'test', component: TestModel }
    // ]
  }
]

const router = new VueRouter({
  mode: 'history',
  base: process.env.BASE_URL,
  linkActiveClass: 'my-active',
  routes
})

export default router
相关推荐
天天扭码7 分钟前
JavaScript 中字符串转字符数组的两种优雅方式
前端·javascript·代码规范
何遇er9 分钟前
在 AI 编程的热潮下对低代码的思考
前端·低代码·ai编程
何遇er12 分钟前
一句 Prompt 自动生成表单:我在低代码平台里是怎么接入生成式 AI 的
前端·低代码·ai编程
_一条咸鱼_14 分钟前
Vue 指令模块深度剖析:从基础应用到源码级解析(十二)
前端·javascript·面试
薯条不要番茄酱22 分钟前
【JavaEE初阶】多线程重点知识以及常考的面试题-多线程进阶(一)
java·前端·java-ee
苹果酱056732 分钟前
redis系列--1.redis是什么
java·vue.js·spring boot·mysql·课程设计
只会安静敲代码的 小周43 分钟前
uniapp上传图片时(可选微信头像、相册、拍照)
前端·微信·uni-app
kovlistudio1 小时前
红宝书第四十六讲:Node.js基础与API设计解析
前端·javascript·node.js
陈哥聊测试1 小时前
这款自研底层框架,你说不定已经用上了
前端·后端·开源
m0_zj1 小时前
41.[前端开发-JavaScript高级]Day06-原型关系图-ES6类的使用-ES6转ES5
开发语言·javascript·es6