Vue-56、Vue技术路由的使用

路由

1、理解:一个路由(route)就是一种映射关系(key-value),多个路由需要路由器(router)进行管理。

2、前端路由:key是路径,value是组件

1、基本使用

vue-router3 只能在vue3中使用

vue-router3 才能在vue2中使用

1、vue2安装

javascript 复制代码
npm i vue-router@3  或者cnpm i vue-router@3

vue3安装

javascript 复制代码
npm i vue-router@4  或者cnpm i vue-router@4

2、应用插件:Vue.use(VueRouter)

3、编写router配置项

javascript 复制代码
//该文件专门用于创建整个应用的路由器
import VueRouter from 'vue-Router'
//引入组件
import About from '../components/About'
import Home from  '../components/Home'
const router = new VueRouter({
    routes:[
        {
            path:'/about',
            component:About
        },
        {
            path:'/home',
            component:Home
        },
    ]
});
export default router;

4、实现切换(active-class可配置高亮样式)

javascript 复制代码
<router-link class="list-group-item" active-class="active" to="/about">About</router-link>

5、指示展示位置

javascript 复制代码
<router-view></router-view>

2、几个注意点

1、路由组件通常存放在pages文件夹,一般组件通常存放在components文件夹

2、通过切换,"隐藏"了的路由组件,默认是被销毁掉的,需要的时候再去挂载。

3、每个组件都有自己的$store属性,里面存储着自己的路由信息。

4、整个应用只有一个router,可以通过组件的$router属性获取到。

3、多级路由

1、配置路由规则,使用children配置项

javascript 复制代码
routes:[
        {
            path:'/about',
            component:About
        },
        {
            path:'/home',
            component:Home,
            children:[
                {
                    path:'news',
                    component:News
                },
                {
                    path:'message',
                    component:Message
                }
            ]
        },
    ]

2、跳转(要写完整路径)

javascript 复制代码
<router-link class="list-group-item" active-class="active" to="/home/news">News</router-link>
相关推荐
Smile_Gently1 小时前
前端:最简单封装nmp插件(组件)过程。
前端·javascript·vue.js·elementui·vue
nihui1236 小时前
Uniapp 实现顶部标签页切换功能?
javascript·vue.js·uni-app
luckycoke8 小时前
小程序立体轮播
前端·css·小程序
一 乐8 小时前
高校体育场管理系统系统|体育场管理系统小程序设计与实现(源码+数据库+文档)
前端·javascript·数据库·spring boot·高校体育馆系统
懒羊羊我小弟8 小时前
常用Webpack Loader汇总介绍
前端·webpack·node.js
shengmeshi8 小时前
vue3项目img标签动态设置src,提示:ReferenceError: require is not defined
javascript·vue.js·ecmascript
BillKu8 小时前
vue3中<el-table-column>状态的显示
javascript·vue.js·elementui
祈澈菇凉8 小时前
ES6模块的异步加载是如何实现的?
前端·javascript·es6
我爱学习_zwj9 小时前
4.从零开始学会Vue--{{组件通信}}
前端·javascript·vue.js·笔记·前端框架
顾比魁9 小时前
XSS盲打:当攻击者“盲狙”管理员
前端·网络安全·xss