用vue router如何获得当前页面的路由?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用vue router如何获得当前页面的路由?相关的知识,希望对你有一定的参考价值。

用vue router如何获得当前页面的路由的方法如下:

路由器将自渲染对应的组件以及更新路由信息:

其中<router-view>可以传递props,支持v-ref,同时也可以使用v-transition和transition-mode来获得场景切换效果,被渲染的组件将注册到父级组件的this.$对象上。

路由对象和路由匹配:
路由对象,即$router会被注入每个组件中,可以利用它进行一些信息的获取。

如属性 说明:

$route.path 当前路由对象的路径,如'/vi
$route.query 请求参数,如/foo?user=1获取到query.user = 1
$route.router 所属路由器以及所属组件信息
$route.matched 数组,包含当前匹配的路径中所包含的所有片段所对应的配置参数对象。
$route.name 当前路径名字

当然,你也可以在自己定义路由规则(map)的时候自定义字段,用以特殊目的。

这里只是做了一些简单的介绍,最后,更多高级用法请参考官方文档。

参考技术A

可以使用vuex-router-sync将router放入到store中进行数据同步,地址: https://github.com/vuejs/vuex...

怎么使用文档很清楚,不再赘述。

加入之后 你在vue devtools控制台就可以看到router属性了。当然也可以取值操作了。

vue-router 路由

vue-router是Vue.js官方的路由插件,用于构建单页面应用。传统的页面应用,是用一些超链接来实现页面切换和跳转的。在vue-router单页面应用中,则是路径之间的切换,也就是组件的切换。路由模块的本质 就是建立起url和页面之间的映射关系。

下面是vue-router的登录注册例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>router举例</title>
    <style>
        .active{
            color:red;
        }
    </style>
</head>
<body>
    <div id="app">
        <!-- 定义路径如何跳转 to属性定义路径 -->
        <!-- router-link标签默认被解析成a链接  -->
        <!-- tag属性可以定义具体是哪个标签 -->
        <router-link to="/login" tag="span">登录</router-link>
        <router-link to="/resign">注册</router-link>
        <router-view></router-view>
        <!-- router-view定义组件显示的容器 -->
    </div>
    <script src="lib/vue.js"></script>
    <script src="vue-router-3.0.1.js"></script>
    <!-- 引入router文件 -->
    <script>
        var tem1 = {
            template: "<h1>登陆组件</h1>"
        }
        var tem2 = {
            template: "<h1>注册组件</h1>"
        }
        // 实例化vuerouter,var routerObj = new VueRouter({})
        // 参数routes,是一个数组,定义路由匹配规则(在什么路径下显示什么组件) 
        // routes有两个参数 path和component
        // path:监听的路由的地址
        // component:表示在这个地址下显示哪个组件
        // redirect:代表路由的重定向 在这个路径下,把地址重新定义
        var routerObj = new VueRouter({
            routes: [
                { path: "/", redirect: "/login" },
                { path: "/login", component: tem1 },
                { path: "/resign", component: tem2 },
            ],
            //linkActiveClass定义router-link被激活时的类名
            linkActiveClass:"active"
        })
        //把定义的路由规则放在new vue中
        var vm = new Vue({
            el: "#app",
            router: routerObj
            //把定义的路由规则放在new vue中
        })
    </script>
</body>
</html>

如果要定义子路由用children表示,它的属性也有path、component

v-router传参:

Ⅰ、query传参

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>query传参</title>
</head>
<body>
    <div id="app">
        <router-link to="/args?year=90&age=20" >query传参</router-link>
        <router-view></router-view>
    </div>
    <script src="lib/vue.js"></script>
    <script src="lib/vue-router-3.0.1.js"></script>
    <script>
        var tem = {
            template: "<h1>传参year为{{$route.query.year}}传参age为{{$route.query.age}}</h1>",
            data(){
                return {
                    id:this.$route.query.year,
                    name:this.$route.query.age
                }
            },
        }
        var routerObj = new VueRouter({
            routes: [
                { path: "/", redirect: "/args" },
                { path: "/args", component: tem },
            ],
        })
        var vm = new Vue({
            el: "#app",
            router: routerObj
        })
    </script>
</body>
</html>

Ⅱ、params传参

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>params传参</title>
</head>
<body>
    <div id="app">
        <router-link to="/args/90/20" >params传参</router-link>
        <router-view></router-view>
    </div>
    <script src="lib/vue.js"></script>
    <script src="lib/vue-router-3.0.1.js"></script>
    <script>
        var tem = {
            template: "<h1>传参year为{{$route.params.year}}传参age为{{$route.params.age}}</h1>",
            data(){
                return {
                    id:this.$route.params.year,
                    name:this.$route.params.age
                }
            },
        }
        var routerObj = new VueRouter({
            routes: [
                { path: "/", redirect: "/args" },
                { path: "/args/:year/:age", component: tem },
            ],
        })
        var vm = new Vue({
            el: "#app",
            router: routerObj
        })
    </script>
</body>
</html>

 

以上是关于用vue router如何获得当前页面的路由?的主要内容,如果未能解决你的问题,请参考以下文章

vue刷新当前路由:router-view 复用组件时不刷新的3种解决方案总结

vue路由如何返回到指定页面

vue中使用provide和inject刷新当前路由(页面)

vue-router 如何在当前路由下重新点击当前路由的router-link实现刷新

vue中实现刷新路由

vue项目刷新当前页面