位置: IT常识 - 正文

若依框架前端切换TagView时刷新问题(若依框架用到的技术)

编辑:rootadmin
若依框架前端切换TagView时刷新问题

推荐整理分享若依框架前端切换TagView时刷新问题(若依框架用到的技术),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:若依框架入门,若依框架部署,若依框架入门,若依框架前后端分离,若依框架用到的技术,若依框架前端如何通过后端加载页面,若依框架前端如何通过后端加载页面,若依框架前后端分离,内容如对您有帮助,希望把文章链接给更多的朋友!

若依框架点击顶部tag切换时,永远都是刷新的。刷新问题两种情况:普通view切换时刷新及iFrame切换刷新 一、普通view切换时刷新

原因是view的name与在菜单填写的大小写不一致,按若依框架规则,路由地址必须写为 camel 驼峰命名形式,组件名称必须写为 pascal首字母全大写的形式。

参考:若依 | 点击顶部 tag 标签不自动刷新 - shayloyuki - 博客园

二、iFrame切换刷新问题

若依框架前端切换TagView时刷新问题(若依框架用到的技术)

 原因是iframe无法通过keep-alive缓存内容节点,每次都需要重新渲染刷新,iframe中keep-alive机制失效原因:iframe页里的内容并不属于节点的信息,所以使用keep-alive依然会重新渲染iframe内的内容。而且iframe每一次渲染就相当于打开一个新的网页窗口,即使把节点保存下来,在渲染时iframe页还是刷新的。

参考:1.vue中keep-alive对引入iframe的页面无效,实现iframe页面缓存问题_vue iframe 缓存_ll7425的博客-CSDN博客

2.GitHub - jmx164491960/vue-iframe-demo: 在vue中实现iframe keep-alive

解决思路: route-link点击切换时用route-view渲染呈现,若component为空时则不呈现,可以增加一个iframe组件在route-view旁边,同时监听路由,若是需要iframe呈现则显示,置空component,并给予iframe的src链接就完成呈现,再控制切换时用v-show控制显示当前路由即可。

改造若依步骤: 1.在获取路由时,判断iframe标识的置空component,打开文件src\store\modules\permission.js

 

2.改造route-view呈现iframe内容 (暂时没空分析,不懂的加好友提问吧,把代码贴上来)

修改文件src\layout\components\AppMain.vue

<template>  <section class="app-main">    <transition name="fade-transform" mode="out-in">      <keep-alive :include="cachedViews">        <router-view :key="key" />      </keep-alive>    </transition>    <!-- iframe页 -->    <iframe v-for="item in componentsArr" :ref="item.name" :id="item.name" frameborder="no"      :style="'width: 100%; height:' +height" scrolling="auto" v-show="$router.currentRoute.path.endsWith(item.path)"/>  </section></template><script>import Cookies from "js-cookie";export default {  name: "AppMain",  data() {    return {      componentsArr: [],      height: document.documentElement.clientHeight - 94.5 + "px;",    };  },  created() {    // 设置iframe页的数组对象    const componentsArr = this.getComponentsArr();        this.componentsArr = componentsArr;    // 判断当前路由是否iframe页    setTimeout(() => {      this.isOpenIframePage();    }, 200);      },  mounted: function () {    setTimeout(() => {      this.loading = false;    }, 300);    const that = this;    window.onresize = function temp() {      that.height = document.documentElement.clientHeight - 94.5 + "px;";    };  },  computed: {    cachedViews() {      return this.$store.state.tagsView.cachedViews;    },    key() {      return this.$route.path;    },      },  watch: {    $route() {      // 判断当前路由是否iframe页      this.isOpenIframePage();    },  },  methods: {    // 根据当前路由设置hasOpen    isOpenIframePage() {        debugger;        var path = this.$router.currentRoute.path.split("/").pop();            var iframe=this.$refs[path];      if(iframe)      {        iframe=iframe[0];      }      if (iframe&&!iframe.isbindsrc) {        this.code = this.$router.currentRoute.query.code;        let menuId = this.$router.currentRoute.meta.menuId;        let uuid = Cookies.get("uuid");        let menuCode = this.$router.currentRoute.meta.menuCode;        let link =          this.$router.currentRoute.meta.frameAddress ||          "/yizumiapi/yisee/tabs2";        if (link.indexOf("?") >= 0) {          link += "&";        } else {          link += "?";        }        let url =          link + "menuId=" + menuId + "&uuid=" + uuid + "&mcode=" + menuCode;          iframe.src = url;          iframe.isbindsrc="true"      }    },    // 遍历路由的所有页面,把含有iframeComponent标识的收集起来    getComponentsArr() {      const routers = this.$store.state.permission.iframeRoutes; //this.$router;      //const routers = router.options.routes;      var iframeMenus = [];      var genMenus = (routes) => {        routes.forEach((item, index) => {          if (item.meta && item.meta.frameAddress) {            var it = Object.assign(item);            delete it.children;                       iframeMenus.push(it);          }          if (item.children) {            genMenus(item.children);          }        });      };      genMenus(routers);      return iframeMenus;    },  },};</script><style lang="scss" scoped>.app-main {  /* 50= navbar  50  */  min-height: calc(100vh - 50px);  width: 100%;  position: relative;  overflow: hidden;}.fixed-header+.app-main {  padding-top: 50px;}.hasTagsView {  .app-main {    /* 84 = navbar + tags-view = 50 + 34 */    min-height: calc(100vh - 84px);  }  .fixed-header+.app-main {    padding-top: 84px;  }}</style><style lang="scss">// fix css style bug in open el-dialog.el-popup-parent--hidden {  .fixed-header {    padding-right: 17px;  }}</style>

src\store\modules\permission.js 代码

import auth from '@/plugins/auth'import router, { constantRoutes, dynamicRoutes } from '@/router'import { getRouters } from '@/api/menu'import Layout from '@/layout/index'import ParentView from '@/components/ParentView'import InnerLink from '@/layout/components/InnerLink'const permission = { state: { routes: [], addRoutes: [], defaultRoutes: [], topbarRouters: [], sidebarRouters: [], iframeRoutes: [], }, mutations: { SET_ROUTES: (state, routes) => { state.addRoutes = routes state.routes = constantRoutes.concat(routes) }, SET_DEFAULT_ROUTES: (state, routes) => { state.defaultRoutes = constantRoutes.concat(routes) }, SET_TOPBAR_ROUTES: (state, routes) => { state.topbarRouters = routes }, SET_SIDEBAR_ROUTERS: (state, routes) => { state.sidebarRouters = routes }, SET_IFRAME_ROUTERS: (state, routes) => { state.iframeRoutes = routes }, }, actions: { // 生成路由 GenerateRoutes({ commit },appId) { return new Promise(resolve => { // 向后端请求路由数据 getRouters(appId).then(res => { const sdata = JSON.parse(JSON.stringify(res.data)) const rdata = JSON.parse(JSON.stringify(res.data)) const sidebarRoutes = filterAsyncRouter(sdata) const rewriteRoutes = filterAsyncRouter(rdata, false, true) const asyncRoutes = filterDynamicRoutes(dynamicRoutes); rewriteRoutes.push({ path: '*', redirect: '/404', hidden: true }) router.addRoutes(asyncRoutes); commit('SET_ROUTES', rewriteRoutes) commit('SET_SIDEBAR_ROUTERS', constantRoutes.concat(sidebarRoutes)) commit('SET_DEFAULT_ROUTES', sidebarRoutes) commit('SET_TOPBAR_ROUTES', sidebarRoutes) debugger; commit('SET_IFRAME_ROUTERS', iframeRoutes) resolve(rewriteRoutes) }) }) } }}var iframeRoutes=[];// 遍历后台传来的路由字符串,转换为组件对象function filterAsyncRouter(asyncRouterMap, lastRouter = false, type = false) { return asyncRouterMap.filter(route => { if (type && route.children) { route.children = filterChildren(route.children) } if (route.component) { // Layout ParentView 组件特殊处理 if (route.component === 'Layout') { route.component = Layout } else if (route.component === 'ParentView') { route.component = ParentView } else if (route.component === 'InnerLink') { route.component = InnerLink } else { if(route.meta&&route.meta.frameAddress) { route.component=undefined; if(iframeRoutes.filter(c=>c.name==route.name).length==0) {iframeRoutes.push(route)} } else{ route.component = loadView(route.component) } } } if (route.children != null && route.children && route.children.length) { route.children = filterAsyncRouter(route.children, route, type) } else { delete route['children'] delete route['redirect'] } return true })}function filterChildren(childrenMap, lastRouter = false) { var children = [] childrenMap.forEach((el, index) => { if (el.children && el.children.length) { if (el.component === 'ParentView' && !lastRouter) { el.children.forEach(c => { c.path = el.path + '/' + c.path if (c.children && c.children.length) { children = children.concat(filterChildren(c.children, c)) return } children.push(c) }) return } } if (lastRouter) { el.path = lastRouter.path + '/' + el.path } children = children.concat(el) }) return children}// 动态路由遍历,验证是否具备权限export function filterDynamicRoutes(routes) { const res = [] routes.forEach(route => { if (route.permissions) { if (auth.hasPermiOr(route.permissions)) { res.push(route) } } else if (route.roles) { if (auth.hasRoleOr(route.roles)) { res.push(route) } } }) return res}export const loadView = (view) => { if (process.env.NODE_ENV === 'development') { return (resolve) => require([`@/views/${view}`], resolve) } else { // 使用 import 实现生产环境的路由懒加载 return () => import(`@/views/${view}`) }}export default permission
本文链接地址:https://www.jiuchutong.com/zhishi/300076.html 转载请保留说明!

上一篇:计算机视觉基础学习-图像拼接(计算机视觉基础知识)

下一篇:【node进阶】深入浅出前后端身份验证(下)---JWT(node实战)

  • 笔记本散热器哪个牌子好一点(笔记本散热器哪个牌子好)(笔记本散热器哪里有卖的)

    笔记本散热器哪个牌子好一点(笔记本散热器哪个牌子好)(笔记本散热器哪里有卖的)

  • 华为nova9有nfc吗(nova9带nfc吗)

    华为nova9有nfc吗(nova9带nfc吗)

  • 荣耀play6T处理器(荣耀play5t参数配置)

    荣耀play6T处理器(荣耀play5t参数配置)

  • oppo手机照片怎么重命名发给别人(oppo手机照片怎么转换成pdf)

    oppo手机照片怎么重命名发给别人(oppo手机照片怎么转换成pdf)

  • 操作不成功,无法添加朋友(操作不成功,无法获取附近的人怎么回事苹果手机)

    操作不成功,无法添加朋友(操作不成功,无法获取附近的人怎么回事苹果手机)

  • 物联卡网速慢怎么调(物联卡网速慢怎么样设置快一点)

    物联卡网速慢怎么调(物联卡网速慢怎么样设置快一点)

  • flash模式是什么意思(flash mode)

    flash模式是什么意思(flash mode)

  • 腾讯会员可以扫码给别人登录吗(腾讯会员可以扫码登录吗其它手机)

    腾讯会员可以扫码给别人登录吗(腾讯会员可以扫码登录吗其它手机)

  • 抖音为什么下载不了呢(抖音为什么下载不了视频)

    抖音为什么下载不了呢(抖音为什么下载不了视频)

  • wps单元格内换行(wps单元格换行打字)

    wps单元格内换行(wps单元格换行打字)

  • 抖音铁粉怎么获得(抖音铁粉是怎么计算的)

    抖音铁粉怎么获得(抖音铁粉是怎么计算的)

  • 双卡手机只显示一个卡怎么回事(双卡手机只显示一个卡重启后恢复)

    双卡手机只显示一个卡怎么回事(双卡手机只显示一个卡重启后恢复)

  • 导入iphone视频找不到(导入苹果的视频怎么看)

    导入iphone视频找不到(导入苹果的视频怎么看)

  • 网易云音乐下载的歌曲能永久听吗(网易云音乐下载到手机本地)

    网易云音乐下载的歌曲能永久听吗(网易云音乐下载到手机本地)

  • 苹果11全网通是什么意思(苹果11全网通嘛)

    苹果11全网通是什么意思(苹果11全网通嘛)

  • 苹果售后中心给验机吗(苹果售后中心给退货吗)

    苹果售后中心给验机吗(苹果售后中心给退货吗)

  • 乐视2锁屏密码忘了怎么办(乐视2锁屏密码是多少)

    乐视2锁屏密码忘了怎么办(乐视2锁屏密码是多少)

  • oppok5是玻璃机身吗(oppok5后面的玻璃摔碎了该怎么办?)

    oppok5是玻璃机身吗(oppok5后面的玻璃摔碎了该怎么办?)

  • 手机显示npc是什么意思(手机显示npc是什么)

    手机显示npc是什么意思(手机显示npc是什么)

  • 抖音作品怎么重新编辑(抖音作品怎么重新编辑文案)

    抖音作品怎么重新编辑(抖音作品怎么重新编辑文案)

  • 央视影音下载的视频在哪里(央视影音下载的视频看不了)

    央视影音下载的视频在哪里(央视影音下载的视频看不了)

  • 华为的充电器叫什么(华为的充电器叫什么头)

    华为的充电器叫什么(华为的充电器叫什么头)

  • 淘宝店铺关门了找谁保修(淘宝怎么开店铺卖货)

    淘宝店铺关门了找谁保修(淘宝怎么开店铺卖货)

  • 苹果x手机定位在哪里设置(苹果X手机定位怎么开)

    苹果x手机定位在哪里设置(苹果X手机定位怎么开)

  • 腾讯视频qq登不上(腾讯视频QQ登不上是怎么回事)

    腾讯视频qq登不上(腾讯视频QQ登不上是怎么回事)

  • 几款实用的VUE移动端UI框架(vue移动)

    几款实用的VUE移动端UI框架(vue移动)

  • 股份公司解散是什么?
  • 幼儿园账务处理及报税
  • 个体工商户增值税怎么计算
  • 药店的主营业务有哪些
  • 油票发票在报销中怎么开
  • 个税是每个月都扣吗
  • 销售收入是不是营业收入
  • 施工单位开具发票税务税率
  • 应收票据资产负债表
  • 转登记为小规模纳税人政策
  • 收到固定资产抵账增值税计税基础
  • 机动车发票红冲可以作废吗
  • 前期认证未抵扣
  • 关联方费用分摊是否要调账
  • 公户没有进账,可以开发票吗?
  • 普票开票开给个人怎么开
  • 设备维保费税率怎么算
  • 企业所得税计提分录怎么写
  • 油罐车运输费用怎么算
  • 计提印花税怎么做凭证
  • 公司租赁房屋的物业费怎么入账
  • 研发费用的会计和税法的不同
  • 一般纳税人开税票
  • 进货折让会计分录
  • Win11怎么自定义鼠标指针图案
  • windows右键刷新总是卡住
  • 将原材料变成成品的过程
  • 怎么升级鸿蒙系统3.1
  • linux系统的
  • mac键盘快捷键设置
  • linux解压安装
  • 前端大屏适配几寸显示器
  • thinkphp ide
  • PHP:iconv_substr()的用法_iconv函数
  • 含税价怎么计算增值税
  • 免征个人所得税33种情形
  • chrome浏览器快捷方式
  • php的oop的理解
  • zentaophp框架
  • 图片格式转换pdf
  • 软考备考时间
  • css教程网站
  • 帝国cms移动端设置教程
  • 红字信息表重复了怎么办
  • 认证发票可以分两次进行吗
  • mysql innodb存储结构
  • 国税联网状态怎么没显示
  • phpmyadmin密码修改
  • 增值税附加税的计算基数
  • 水利建设基金计提会计分录
  • 先收票后收货
  • 存货盘点后的检查
  • 代收会计分录
  • 跨年度暂估成本的账务处理
  • 法人名称是填公司名吗
  • 连锁店的总部取名
  • 企业红包是什么骗局吗
  • 工厂的委托加工怎么写
  • 贴现办理流程
  • sql server中查看创建的数据库命令
  • centos bz
  • centos运行文件
  • ghost出现错误
  • win7小喇叭有个红叉
  • ubuntu切换登录用户
  • win7电脑关机出现0xc0000142是什么原因
  • win10预览设置
  • unet遥感图像分割
  • Node.js中的事件循环是什么意思
  • 在android的activity活动中
  • html概念及作用
  • JavaScript中的方法名不区分大小写
  • python xml.etree.ElementTree遍历xml所有节点实例详解
  • javascript基础笔记
  • 技术总结结束语
  • javascript构造函数创建对象
  • 税务风险科是干什么的
  • 江苏联通客服电话人工服务号码
  • 增值税发票报税流程
  • 海关行政处罚实施条例的适用范围
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设