zoukankan      html  css  js  c++  java
  • vue路由传参的三种方式以及解决vue路由传参页面刷新参数丢失问题

      最近项目中涉及到跨页面传参数和后台进行数据交互,看到需求之后第一反应就是用路由传参来解决;Vue中给我们提供了三种路由传参方式,下面我们一个一个的来看一下:

      方法一:params传参:

      

    this.$router.push({
            name:"admin",
        //这里的params是一个对象,id是属性名,item.id是值(可以从当前组件或者Vue实例上直接取) params:{id:item.id} })
    //这个组件对应的路由配置 {
      //组件路径 path:
    '/admin',
      //组件别名 name:
    'admin',
      //组件名 component: Admin, }

      通过params传递参数,如果我们想获取id的 参数值,我们可以通过this.$route.params.id这种方式来打印出来就可以得到了;(注意:获取参数的时候是$route,跳转和传参的时候是$router)

      方法二:路由属性配置传参:

    this.$router.push({
            name:"/admin/${item.id}",
    })       
    
    //这个组件对应的路由配置
    {
      //组件路径
        path: '/admin:id',
      //组件别名
        name: 'admin',
      //组件名
        component: Admin,
    }

      通过路由属性配置传参我们可以用this.$route.params.id来获取到id的值,注意this.$router.push方法里面路径带的是值,路由配置项那里带的是变量名(属性名)来实现的对应;

      以上两种传参方式基本上可以理解为ajax中的post请求方式,参数都是不可见的,但是上面两种方法都有一个弊端,就是当页面刷新了是获取不到参数值的,那么有没有一种方法是页面刷新之后参数依然存在呢?

      方法三:query传参

      

    this.$router.push({
            path:"/admin",
         query:{id:item.id} })
    //这个组件对应的路由配置 {   //组件路径 path: '/admin',   //组件别名 name: 'admin',   //组件名 component: Admin, }

      第三种方式是用query来传参,这种方式是可以解决页面刷新参数消失问题的,这种方式可以理解为是ajax中的get方法,参数是直接在url后面添加的,参数是可见的,所以解决页面刷新参数消失问题建议使用方法三来解决;

      

      其实解决页面刷新参数丢失问题的方案还有很多,比如把参数存在sessionStorange或者localStorange中都是可行的,不过我们既然用vue框架,就要用vue的方式来解决问题。这里只是想告诉大家,问题的解决方案可以多种多样,要学会用多种方式或者说多种方案来解决一个问题,不要有太多的局限性!

    本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。
  • 相关阅读:
    Can't use Subversion command line client: svn
    SpringMVC配置easyui-datagrid
    找不到提交和更新按钮,subversion不见了,无法更新和上传代码
    静态资源[org.springframework.web.servlet.PageNotFound]
    Field 'id' doesn't have a default value
    MySql 插入数据中文乱码
    Junit 测试 Spring
    mybatis动态SQL
    Mybatis 3.3.0 Log4j配置
    MappingJacksonHttpMessageConverter过期
  • 原文地址:https://www.cnblogs.com/dengyao-blogs/p/11399676.html
Copyright © 2011-2022 走看看