From 16d8b71e21dc7298b30f46bf264cd9b3589a6978 Mon Sep 17 00:00:00 2001 From: who's hu <hup_dev@outlook.com> Date: 星期二, 22 八月 2023 17:25:19 +0800 Subject: [PATCH] update ruoyi-ui/src/permission.js. 由于重定向url存在 http://xxx.xx.xxx/{id}?param={a}&name={b} 的场景, 当未登录访问时, 通过改js封装登录后重定向参数, 会丢失?后的query params 如: 访问 http://localhost:1024/core/doc/doc?id=1683734914907807745&version=31 期望 http://localhost:1024/login?redirect=%2Fcore%2Fdoc%2Fdoc%3Fid%3D1683734914907807745%26version%3D31 实际通过 to.fullPath 封装后 获得 http://localhost:1024/login?redirect=%2Fcore%2Fdoc%2Fdoc%3Fid%3D1683734914907807745&version=31 --- ruoyi-ui/src/layout/components/InnerLink/index.vue | 62 ++++++++++++++++++++---------- 1 files changed, 41 insertions(+), 21 deletions(-) diff --git a/ruoyi-ui/src/layout/components/InnerLink/index.vue b/ruoyi-ui/src/layout/components/InnerLink/index.vue index 227ff2a..6edcdec 100644 --- a/ruoyi-ui/src/layout/components/InnerLink/index.vue +++ b/ruoyi-ui/src/layout/components/InnerLink/index.vue @@ -1,27 +1,47 @@ +<template> + <div :style="'height:' + height" v-loading="loading" element-loading-text="正在加载页面,请稍候!"> + <iframe + :id="iframeId" + style="width: 100%; height: 100%" + :src="src" + frameborder="no" + ></iframe> + </div> +</template> + <script> export default { - data() { - return {}; - }, - render() { - const { $route: { meta: { link } }, } = this; - if ({ link }.link === "") { - return "404"; + props: { + src: { + type: String, + default: "/" + }, + iframeId: { + type: String } - let url = { link }.link; - const height = document.documentElement.clientHeight - 94.5 + "px"; - const style = { height: height }; - - return ( - <div style={style}> - <iframe - src={url} - frameborder="no" - style="width: 100%; height: 100%" - scrolling="auto" - ></iframe> - </div> - ); }, + data() { + return { + loading: false, + height: document.documentElement.clientHeight - 94.5 + "px;" + }; + }, + mounted() { + var _this = this; + const iframeId = ("#" + this.iframeId).replace(/\//g, "\\/"); + const iframe = document.querySelector(iframeId); + // iframe页面loading控制 + if (iframe.attachEvent) { + this.loading = true; + iframe.attachEvent("onload", function () { + _this.loading = false; + }); + } else { + this.loading = true; + iframe.onload = function () { + _this.loading = false; + }; + } + } }; </script> -- Gitblit v1.9.2