前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue教程(路由Router-传值)

Vue教程(路由Router-传值)

作者头像
用户4919348
发布2019-08-06 14:48:07
1K0
发布2019-08-06 14:48:07
举报
文章被收录于专栏:波波烤鸭波波烤鸭

  本文我们来介绍下在Vue中路由的传参问题

Vue路由传参

  首先我们来准备一个基本路由的页面,如下:

代码语言:javascript
复制
<!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>Document</title>
    <script src="./lib/vue-2.4.0.js"></script>
    <script src="./lib/vue-router-3.0.1.js"></script>
    
</head>
<body>
    <div id="app">

        <!-- router-link 默认渲染为一个a 标签 -->
        <router-link to="/login" >登录</router-link>
        <router-link to="/register">注册</router-link>

        <router-view></router-view>
    </div>

    <script>
        // 创建两个子组件 模板对象
        var login = {
            template: "<h3>登录模块</h3>"
        }

        var register = {
            template: "<h3>注册模块</h3>"
        }

        // 创建一个路由对象, 当 导入 vue-router 包之后,在 window 全局对象中,
        // 就有了一个 路由的构造函数叫做 VueRouter
        var routerObj = new VueRouter({
            // 配置路由规则
            routes:[
                {path:"/",redirect:"/login"},
                {path: "/login" , component: login},
                {path: "/register" , component: register}
            ]
        })
        var vm = new Vue({
            el: "#app",
            data: {},
            methods: {},
            // 将路由规则对象,注册到 vm 实例上,用来监听 URL 地址的变化,
            // 然后展示对应的组件
            router:routerObj
        })
    </script>
</body>
</html>

效果如下:

在这里插入图片描述
在这里插入图片描述

第一种方式

  实现路由传参的第一种方式是在 router-linkto 跳转地址后拼接,如下

在这里插入图片描述
在这里插入图片描述

那么怎么获取链接地址中拼接的数据呢?往下看:

在这里插入图片描述
在这里插入图片描述

通过工具调试,我们发现传递的数据实际保存在了 $route.query 对象中,那么我们就可以通过此对象来获取了。

在这里插入图片描述
在这里插入图片描述

效果如下:

在这里插入图片描述
在这里插入图片描述

第二种方式

  第二种方式同样是修改 router-link 中的 to 属性中的地址信息,只是写法和前面不一样,如下

在这里插入图片描述
在这里插入图片描述

这时我们需要在路由规则中特殊设置下对应关系,如下

在这里插入图片描述
在这里插入图片描述

这时我们在看下传递的数据真实的存储位置

在这里插入图片描述
在这里插入图片描述

这时我们发现数据存储在了 $route.params 对象中,那么我们获取传递数据的方式为如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

搞定~

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年08月05日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Vue路由传参
    • 第一种方式
      • 第二种方式
      相关产品与服务
      对象存储
      对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档