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 跳转页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
element-ui自定义message-box自定义样式不生效的解决
这篇文章主要介绍了element-ui自定义message-box自定义样式不生效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-09-09el-elementUI使用el-date-picker选择年月
本文主要介绍了el-elementUI使用el-date-picker选择年月,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧2024-02-02
最新评论