vue路由对不同界面进行传参及跳转的总结


Posted in Javascript onApril 20, 2019

最近在做一个公众号的商城项目,主要用的VUE+MUI,其实今天这个点对于有过项目经验的前端工作者来说是最基础的,但也是必须要掌握的,今天小编主要是记录下传参和跳转的一些总结(仅供参考)。

首先我们先上代码吧!

<router-link :to="{path:'/editaddress',query:{ id:item.id }}"> 
  <div class="top_left_center">
     <img src="/static/images/details/location.png" alt="" class="location_img">
      <span style="color:#f40;font-size:15px;">点击编辑</span>
  </div>
</router-link> 

这个是我常用的传参及跳转路由的方法,下面剪短说一下这个代码,在router-link中:to后面跟着的就是主角(跳转、传参)的内容了,其实我们在从后台拿到数据遍历后,每一个对应的id都会有,这里用的query:{id:item,id},其实就是把遍历对应的id传到path

对应的那个界面,这个常出现在列表页到详情页页这里(当然不只是这里了,其他地方用的很多很多)。

对于传参的方式还是要说下的多余的:

query和params:

a.像这种:to="{path:'/editaddress',query:{ id:item.id }}是query进行传值;这种:to="{path:'/editaddress',params:{ id:item.id }},两种方式传值没什么差别,

但比如在详情页引入值时this.paramsid = this.$route.params.id ---->params引入;this.queryId = this.$route.query.Id---->query引入(当然用name也行)

对于需要进行安全保护的网站其实也可以在此处进行选择params-->name(不显示路径如index/login)--->当然这只是相对query.-->path(显示?后面带的参数如index/login?id=1&&name=asd)安全的方法.

需要说明的这种方法在有的页面刷新会丢失传过来的数据,就是不太稳定。下面是另一个传参的方法倒是可以解决这种问题,先看代码:

request.get('shop/ce/' + this.product_id +'? num='+this.num ,{
          id:this.product_id,
          num:this.num,
        }).then((response) => {
          if(response){
            console.log(this.product_id)
            this.$router.push({path:'/order?pid='+this.product_id})
          }  
        }).catch((ex) => {
        console.log(ex.response)
        })

上面的request只是我封装的一个axios请求方法(主要是方便,不多说),看红线重点,这个地方的传参其实是很优秀的,自己在定义一个变量接收id,因为是写在跳转路径里面的,这样在刷新时人家会一直带着这个ID,数据自然就不会丢失了,在需要接受ID的页面用

this.product_id = this.$route.query.pid存一下就OK了。因此觉得这个方法挺好,需要多加注意。
既然说到这了,我们常用的其实还有抓取不同的id,传给后台,常见的有点击不同列表的商品获取对应的ID,这里我就说一下我用的方法(这个仅仅是记录下)。

<div class="main" v-for="(item,index) in Unpaycontent" :key="index">
            <div class="main_top">
              <div class="imgContral">
                <img :src="item.goods_image">
                <div class="describtion"><a>待支付</a></div>
              </div>
              <div class="details"><p style="color:#000;">{{item.goods_name}}</p></div>
              <div class="main_topright">
                <p>{{item.price}}</p>
                <p>×{{item.num}}</p>
              </div>
              <div class="top_bottom">
                <span style="float:right;">合计:<a style="color:red;">{{item.total_price}}</a></span>
              </div>
            </div>
            <div class="main_bot">
                <a @click="click(item.id)">立即支付</a>
            </div>
          </div>

还是看红线,因为我们在点击的时候传的有item.id,这就解决了传不同ID的头疼问题,在methods里用方法接受时随便定义下改个好看的名字就能很好的把ID拿出来传到后台了,为了展示的详细点,还是贴一下代码吧。

getallData (index) {
      request.get('/shop/orders'+index, {
        
        }).then((response) => {
         
        }).catch((ex) => {
      }) 
    },

这里的item.id就被我变成了index了,其他的就是愉快的给后台解决了。

本文主要是对传参进行简短总结下,如果有其他的好的传参的方法或者本篇我写的有错的地方,欢迎指教!

以上所述是小编给大家介绍的vue路由对不同界面进行传参及跳转的总结详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Jquery截取中文字符串的实现代码
Dec 22 Javascript
JavaScript设置body高度为浏览器高度的方法
Feb 09 Javascript
Javascript中的Callback方法浅析
Mar 15 Javascript
JS实现拖动滚动条评分的效果代码分享
Sep 29 Javascript
JavaScript实现类似淘宝的购物车效果
Mar 16 Javascript
解决Vue+Element ui开发中碰到的IE问题
Sep 03 Javascript
vue项目创建并引入饿了么elementUI组件的步骤
Apr 11 Javascript
浅谈react-router@4.0 使用方法和源码分析
Jun 04 Javascript
原生js代码能实现call和bind吗
Jul 31 Javascript
node.js实现带进度条的多文件上传
Mar 27 Javascript
jQuery实现轮播图源码
Oct 23 jQuery
微信小程序picker组件两列关联使用方式
Oct 27 Javascript
详解Vue+Element的动态表单,动态表格(后端发送配置,前端动态生成)
Apr 20 #Javascript
详解vue使用$http服务端收不到参数
Apr 19 #Javascript
ajaxfileupload.js实现上传文件功能
Apr 19 #Javascript
AjaxFileUpload.js实现异步上传文件功能
Apr 19 #Javascript
读懂CommonJS的模块加载
Apr 19 #Javascript
js module大战
Apr 19 #Javascript
如何根据业务封装自己的功能组件
Apr 19 #Javascript
You might like
一个可查询所有表的“通用”查询分页类
2006/10/09 PHP
php简单静态页生成过程
2008/03/27 PHP
解决PHP mysql_query执行超时(Fatal error: Maximum execution time …)
2013/07/03 PHP
PHPer 需要了解的 5 个 Composer 小技巧
2014/08/18 PHP
PHP版本常用的排序算法汇总
2015/12/20 PHP
javaScript call 函数的用法说明
2010/04/09 Javascript
jQuery之日期选择器的深入解析
2013/06/19 Javascript
jquery左右滚动焦点图banner图片鼠标经过显示上下页按钮
2013/10/11 Javascript
jquery教程ajax请求json数据示例
2014/01/13 Javascript
jquery form 加载数据示例
2014/04/21 Javascript
jQuery增加与删除table列的方法
2016/03/01 Javascript
javascript断点调试心得分享
2016/04/23 Javascript
原生ajax处理json格式数据的实例代码
2016/12/25 Javascript
微信小程序 http请求的session管理
2017/06/07 Javascript
angularjs2 ng2 密码隐藏显示的实例代码
2017/08/01 Javascript
JS实现自定义弹窗功能
2018/08/08 Javascript
小程序Request的另类用法详解
2019/08/09 Javascript
微信小程序学习总结(五)常见问题实例小结
2020/06/04 Javascript
[19:24]DOTA2客户端使用指南 一分钟快速设置轻松超神
2013/09/24 DOTA
python中getattr函数使用方法 getattr实现工厂模式
2014/01/20 Python
Python中正则表达式的用法实例汇总
2014/08/18 Python
如何优雅地改进Django中的模板碎片缓存详解
2018/07/04 Python
Python基于opencv实现的简单画板功能示例
2019/03/04 Python
如何安装并使用conda指令管理python环境
2019/07/10 Python
通过实例解析Python调用json模块
2019/12/11 Python
python 将html转换为pdf的几种方法
2020/12/29 Python
只要五步 就可以用HTML5/CSS3快速制作便签贴特效(图)
2012/06/04 HTML / CSS
韩国知名的家庭购物网站:CJmall
2016/08/01 全球购物
捷克玩具商店:Bambule
2019/02/23 全球购物
促销活动策划方案
2014/01/12 职场文书
毕业生自荐书
2014/02/02 职场文书
《王二小》教学反思
2014/02/27 职场文书
人事部经理岗位职责
2014/03/07 职场文书
个园导游词
2015/02/04 职场文书
机械原理课程设计心得体会
2016/01/15 职场文书
SQL Server作业失败:无法确定所有者是否有服务器访问权限的解决方法
2021/06/30 SQL Server