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 跳转页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue实现一个简单的Grid拖拽布局

    vue实现一个简单的Grid拖拽布局

    这篇文章主要为大家详细介绍了如何利用vue实现一个简单的Grid拖拽布局,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12
  • Vue程序调试的方法

    Vue程序调试的方法

    这篇文章主要介绍了VUE程序调试的方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-06-06
  • 解决vue A对象赋值给B对象,修改B属性会影响到A的问题

    解决vue A对象赋值给B对象,修改B属性会影响到A的问题

    今天小编就为大家分享一篇解决vue A对象赋值给B对象,修改B属性会影响到A的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • Vue中使用wangeditor富文本编辑的问题

    Vue中使用wangeditor富文本编辑的问题

    这篇文章主要介绍了Vue中使用wangeditor富文本编辑的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Vue插件写、用详解(附demo)

    Vue插件写、用详解(附demo)

    本篇文章主要介绍了Vue插件写、用详解(附demo),插件就是指对Vue的功能的增强或补充。有兴趣的可以了解一下。
    2017-03-03
  • Vue不能下载xls以及文件乱码问题解决

    Vue不能下载xls以及文件乱码问题解决

    最近工作中遇到了一些问题,通过查找相关资料终于找到了相关的解决方法,这篇文章主要给大家介绍了关于Vue不能下载xls以及文件乱码问题解决的相关资料,需要的朋友可以参考下
    2022-04-04
  • Vue组件实现评论区功能

    Vue组件实现评论区功能

    这篇文章主要为大家详细介绍了Vue组件实现评论区功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • vue按需引入element Transfer 穿梭框

    vue按需引入element Transfer 穿梭框

    这篇文章主要介绍了vue按需引入element Transfer 穿梭框的相关资料,需要的朋友可以参考下
    2017-09-09
  • Vue的filters(本地)或filter(全局)过滤常用数据类型解析

    Vue的filters(本地)或filter(全局)过滤常用数据类型解析

    这篇文章主要介绍了Vue的filters(本地)或filter(全局)过滤常用数据类型,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • Vue组件间通信的实现方法讲解

    Vue组件间通信的实现方法讲解

    组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互进行直接的引用,所以组件间的相互通信是非常重要的
    2023-01-01

最新评论