Vue 路由规则--传参数

1,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>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">
    <!-- 如果在路由中,使用 查询字符串,给路由传递参数,则 不需要修改 路由规则的 path 属性 -->
    <router-link to="/login?id=10&name=zs">登录</router-link>
    <router-link to="/register?abc=123">注册</router-link>
    <router-view></router-view>
  </div>

  <script>

    var login = {
      template: ‘<h1>登录 --- {{ $route.query.id }} --- {{ $route.query.name }}</h1>‘,
      data(){
        return {
          msg: ‘123‘
        }
      },
      created(){ // 组件的生命周期钩子函数
        console.log(this.$route)
        //这里用query去获取路由传来的参数 注意要带上
        console.log(this.$route.query.id)
        console.log(this.$route.query.name)
      }
    }

    var register = {
      template: ‘<h1>注册</h1>‘,
      created(){
        console.log(this.$route.query.abc)
      }
    }

    var router = new VueRouter({
      routes: [
        { path: ‘/login‘, component: login },
        { path: ‘/register‘, component: register }
      ]
    })

    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: ‘#app‘,
      data: {},
      methods: {},
      // 属性名跟属性值一样 只需要写一个名称
      // router: router
      router
    });
  </script>
</body>

</html>

2,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>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 to="/login/12/ls">登录</router-link>
    <router-link to="/register/我是参数">注册</router-link>

    <router-view></router-view>

  </div>

  <script>

    var login = {
      template: ‘<h1>登录 --- {{ $route.params.id }} --- {{ $route.params.name }}</h1>‘,
      data(){
        return {
          msg: ‘123‘
        }
      },
      created(){ // 组件的生命周期钩子函数
      // 用params去获取参数
        console.log(this.$route.params.id)
      }
    }

    var register = {
      template: ‘<h1>注册 --{{ $route.params.a}}</h1>‘,
      created(){ // 组件的生命周期钩子函数
      // 用params去获取参数
        console.log(this.$route.params.a)
      }
    }

    var router = new VueRouter({
      routes: [
        // 在路由规则中用 :形参 去设置传值的参数
        { path: ‘/login/:id/:name‘, component: login },
        { path: ‘/register/:a‘, component: register }
      ]
    })

    // 创建 Vue 实例,得到 ViewModel
    var vm = new Vue({
      el: ‘#app‘,
      data: {},
      methods: {},
      // router: router
      router
    });
  </script>
</body>

</html>

原文地址:https://www.cnblogs.com/wanguofeng/p/11293922.html

时间: 2024-07-31 05:56:26

Vue 路由规则--传参数的相关文章

vue 路由动态传参 (多个)

动态传参 传值页面  客户列表clientList.vue 路由 router.js 配置路由 接收参数的页面  客户详情CustomerDetails.vue 通过this.$router.params来接收参数对象 打印结果: 原文地址:https://www.cnblogs.com/lpp-11-15/p/12092658.html

vue路由params传参

路由跳转 {name:'',params:{id:''}} 子页面路由接受参数 this.$route.params.id 原文地址:https://www.cnblogs.com/renewload/p/11271242.html

Flask学习 2修改路由规则 传入参数访问url

#!/usr/bin/env python # encoding: utf-8 """ @version: v1.0 @author: cxa @file: flask02.py @time: 2018/04/13 14:55 """ """ 要给 URL 添加变量部分,你可以把这些特殊的字段标记为 <variable_name> , 这个部分将会作为命名参数传递到你的函数.规则可以用 <conve

vue路由传参

vue路由url 传参 :params 从客户列表页 通过路由跳转到客户详情页 查看客户详情时 需要将当前客户的id 和所属企业的id 当做参数传给后台. 在跳转时,将客户id 和企业id 通过路由传参 传给 客户详情页 客户列表: 客户详情 通过 this.$router.params 获取 参数 路由 router.js 路由传一个对象:query 有时我们需要传很多数据过去,为了避免大量拼接,我们可以传一个对象 通过this.$router.query接收对象参数 这里router 路由

MVC之路由规则 (自定义,约束,debug)

自定义路由规则的要求,小范围写在前,大范围写在后.路由规则可以注册多条,路由规则的名称不能重复路由规则有顺序,并且按照顺序进行匹配,建议小范围写在前,大范围写在后.路由规则可以设置约束 即正则表达式路由规则匹配的控制器可以设置命名空间约束 routes.MapRoute( name: "NewShow", url: "{year}-{month}-{day}-{id}", defaults: new { controller = "News",

Vue路由传参及传参后刷新导致参数消失处理

参考:https://blog.csdn.net/qq_43103581/article/details/82260073(vue 路由传递参数,刷新页面后参数丢失) 项目功能需要,要从列表页跳转到第三方提供的URL上(这里第三方页面我是通过iframe引入在详情页,目的是点击返回时可以通过keepAlive让列表页不刷新,如果不通过iframe直接跳第三方链接,那么返回必然会重新拉取数据),一路百度,刚开始使用 this.$router.push({name:'list', params:{i

vue路由传参页面刷新参数丢失问题解决方案

最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决:Vue中给我们提供了三种路由传参方式,下面我们一个一个的来看一下: 方法一:params传参: this.$router.push({ name:"admin", //这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或者Vue实例上直接取) params:{id:item.id} }) //这个组件对应的路由配置 { //组件路径 path: '/admin', //

Vue入门十三、路由的传参和取参

1.查询参login?id=12345 配置:(传参):to="{name:'login', query:{id:'loginid'}}"获取:(取参)this.$route.query.id 2.路由参数 配置:(传参):to="{name:'login', params:{id:'loginid'}}"获取:(取参)this.$route.params.id 3.路径参数register/registerid/info 配置:(传参):to="{nam

Vue - 路由传递参数

Vue 2.0  路由传递参数 Vue 路由传递参数 有两种方式: 一.用name传递参数 两步完成用name传值并显示在模板里: 在路由文件src/router/index.js里配置name属性. 1 2 3 4 5 6 7 routes: [ { path: '/', name: 'Hello', component: Hello } ] 模板里(src/App.vue)用$router.name的形势接收,比如直接在模板中显示: 1 <p>{{ $route.name}}</p&