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);

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值