Vue中路由配置

在脚手架里使用路由(推荐)

1. 安装vue-router到项目中

npm i vue-router@3.4.8

2. 修改目录结构

在这里插入图片描述

3. 主要代码

import Vue from 'vue'
//导入路由模块
import Router from 'vue-router'
//将路由使用的组件导入
import Home from "@/views/Home";
import Second from "@/views/Second";
//在脚手架中需要手动注册路由功能到Vue中
Vue.use(Router)

//创建路由实例对象
    const router = new Router({
            routes: [
                {
                    path: '/',
                    component: Home
                },
                {
                    path:'/second',
                    component:Second
                }
            ]
})
// 导出路由实例
export default router

src/main.js:

import Vue from 'vue'
import App from './App.vue'
//导入路由实例对象
import router from "@/router";
Vue.config.productionTip = false

new Vue(
    {
      //添加到主Vue对象里
      router,
  render: h => h(App),
}).$mount('#app')

RESTFul式传参

路由配置:

var myRouter = new VueRouter({
    routes:[
        //用/:参数名形式书写path
        {path:"/r1/:name/:age",component:"template1"}
    ]
});

链接跳转传参:

<router-link to="/r1/lins/27"></router-link>

JS跳转传参:

this.$router.push("/r1/lins/27");
收参

组件模板(HTML部分)收参:

{{$route.params.name}}
{{$route.params.age}}

组件中JS部分收参:

this.$route.params.name;
this.$route.params.age;

query式传参

query式就是把参数直接以?querystring的形式直接拼接到地址栏上。这种传参方式在路由配置时不需要额外配置参数接收。

链接跳转传参:

<router-link to="/r2?name=lins&age=27"></router-link>

JS跳转传参:

this.$router.push("/r2?name=lins&age=27");
收参

组件模板(HTML部分)收参:

{{$route.query.name}}
{{$route.query.age}}

组件中JS部分收参:

this.$route.query.name;
this.$route.query.age;

$route对象和VueRouter对象

VueRouter对象是控制整个路由系统的对象,切换路由的操作都是依靠VueRouter对象进行的(router-link算是快捷方式),可以通过$router(JS中为this.$router)来获取VueRouter对象。
r o u t e 对象是当前路由的信息对象,可以使用 ‘ route对象是当前路由的信息对象,可以使用` route对象是当前路由的信息对象,可以使用route.params获取当前路由的参数、使用 r o u t e . p a t h ‘ 可以拿到当前路由的路径。( J S 中为 ‘ t h i s . route.path`可以拿到当前路由的路径。(JS中为`this. route.path可以拿到当前路由的路径。(JS中为this.route`)

动态添加路由规则(了解)

有时,我们需要某些路由规则不是在页面刚加载时就生效,而是在满足某些条件时生效。
比如我们做的应用里,有些页面(路由视图)需要在用户登录后才能访问,用户在没有登录时,即使在地址栏中直接输入那些页面的URL,也是无法访问的。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>基本路由</title>
    <script src="vue.2.6.12.js"></script>
    <script src="vue-router.3.4.8.js"></script>
</head>
<body>
<button onclick="test()">按钮</button>
<div id="app">
    <router-link to="/">路由1</router-link>
    <router-link to="/r2">路由2</router-link>
    <router-view></router-view>
</div>
<script>
    let myTemplate1 = {
        template:`<div>AAA-这是路由1-AAA</div>`
    };
    let myTemplate2 = {
        template:`<div>BBB-这是路由2-BBB</div>`
    };
    let myRouter = new VueRouter({
        //写在这里的路由规则,在页面加载时就生效
        routes:[
            {path:"/",component:myTemplate1}
        ]
    });
    let main = new Vue({
        el:"#app",
        router:myRouter
    });

    function test(){
        //动态添加路由规则,和routes数组写法相同
        myRouter.addRoutes([
            {path:"/r2",component:myTemplate2}
        ])
    }
</script>
</body>
</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值