vue 跳转页面$router.resolve和$router.push案例详解

 更新时间:2023年10月12日 10:39:56   作者:青藏阳光  
这篇文章主要介绍了vue 跳转页面$router.resolve和$router.push案例详解,这样实现了既跳转了新页面,又不会让后端检测到页面链接不安全之类的,需要的朋友可以参考下

写下我遇到的问题,调用后端接口返回html字符串包括script标签,现在需要跳转到新页面显示这个html。

push+query传参可以打开新窗口,但参数是在地址栏显示的,可能是script里面再次有触发接口的行为,页面会显示链接不安全之类。

所以改用push+params,但这种是在当前页面打开,不能打开新窗口。

再改用resolve+params,这种跳转到新页面又获取不到参数了。(别的博文也有写到确实如此)

所以想着先用push+query跳页面1且传参,但不渲染页面1且同时再push+params跳转到新页面2(但是没有打开新窗口)

这样实现了既跳转了新页面,又不会让后端检测到页面链接不安全之类的。

代码部分:

地址栏传参跳转

 let routeData = this.$router.resolve({ name: 'hfRecharge', query: { html: response }});
 window.open(routeData.href, '_blank');

再,params传参跳页面,让地址栏不显示参数

  mounted() {
 let routeData = this.$router.push({ name: 'hfRechargeShow', params: { html: this.$route.query.html }});
  }

最后,渲染页面

  mounted() {
    const div = document.createElement('div');
    div.innerHTML = this.$route.params.html;
    document.body.appendChild(div);
    document.forms[0].submit();
  }

23年4月6日

import qs from 'qs'
let routeData = this.$router.resolve({name: 'pageName', query: {form: qs.stringify(response.data)}});

文章前头写过resove+query传参后页面取不到参数,我遇到的情况是我传的参数是个对象,所以利用了qs,在新页面再

const form = qs.parse(this.$route.query.form);

解析为对象就可以.出具体值了。

到此这篇关于vue 跳转页面$router.resolve和$router.push的文章就介绍到这了,更多相关vue 跳转页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 微信小程序使用uni-app一键获取用户信息

    微信小程序使用uni-app一键获取用户信息

    这篇文章主要介绍了微信小程序使用uni-app一键获取用户信息,需要的朋友可以参考下
    2023-01-01
  • vue项目使用luckyexcel预览excel表格功能(心路历程)

    vue项目使用luckyexcel预览excel表格功能(心路历程)

    这篇文章主要介绍了vue项目使用luckyexcel预览excel表格,我总共尝试了2种方法预览excel,均可实现,还发现一种方法可以实现,需要后端配合,叫做KKfileview,本文给大家介绍的非常详细,需要的朋友可以参考下
    2023-10-10
  • 详解vue填坑之解决部分浏览器不支持pushState方法

    详解vue填坑之解决部分浏览器不支持pushState方法

    这篇文章主要介绍了详解vue填坑之解决部分浏览器不支持pushState方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • vue+F2生成折线图的方法

    vue+F2生成折线图的方法

    这篇文章主要为大家详细介绍了vue+F2生成折线图的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • element-ui 中的table的列隐藏问题解决

    element-ui 中的table的列隐藏问题解决

    这篇文章主要介绍了element-ui 中的table的列隐藏问题解决,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • Vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法

    Vue中 v-if 和v-else-if页面加载出现闪现的问题及解决方法

    vue中v-if 和v-else-if在页面加载的时候,不满足条件的标签会加载然后再消失掉,如果要解决这个问题,下面小编给大家带来了实例代码,需要的朋友参考下吧
    2018-10-10
  • this.$router.push携带参数跳转页面的实现代码

    this.$router.push携带参数跳转页面的实现代码

    这篇文章主要介绍了this.$router.push携带参数跳转页面,this.$router.push进行页面跳转时,携带参数有params和query两种方式,本文结合实例代码给大家详细讲解,需要的朋友可以参考下
    2023-04-04
  • Vue3全局组件通信之provide / inject详解

    Vue3全局组件通信之provide / inject详解

    这篇文章主要介绍了Vue3全局组件通信之provide / inject,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-03-03
  • 用Vue实现页面访问拦截的方法详解

    用Vue实现页面访问拦截的方法详解

    大家在做前端项目的时候,大部分页面, 游客都可以直接访问 , 如遇到 需要登录才能进行的操作,页面将提示并跳转到登录界面,那么如何才能实现页面拦截并跳转到对应的登录界面呢,本文小编就来给大家介绍一下Vue实现页面访问拦截的方法,需要的朋友可以参考下
    2023-08-08
  • vue动态修改页面title的两种方法

    vue动态修改页面title的两种方法

    本文主要介绍了vue动态修改页面title的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06

最新评论