今天小编给大家分享一下Vue中如何对iframe实现keep alive无刷新的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Vue的keep-alive原理
要实现对保持iframe页的状态。我们先搞清楚为什么Vue的keep-alive不能凑效。keep-alive原理是把组件里的节点信息保留在了VNode (在内存里),在需要渲染时候从Vnode渲染到真实DOM上。iframe页里的内容并不属于节点的信息,所以使用keep-alive依然会重新渲染iframe内的内容。另外 ,我也尝试有过想法:如果把整个iframe节点保存起来,然后需要切换时把它渲染到目标节点上,能否实现iframe页不被刷新呢?————也是不可行的,iframe每一次渲染就相当于打开一个新的网页窗口,即使把节点保存下来,在渲染时iframe页还是刷新的。实现的思路
既然保持iframe页里的状态很难实现,在这个时候我想到了一个别的方法。能否在Vue的route-view节点上动点手脚?使得在切换非iframe页 的时候使用Vue的路由,当切换iframe页 时则使用 v-show 切换显示与隐藏,使得iframe节点一直不被删除 ,这样就能保持iframe的状态了。我们简陋的实现一下以上的效果,上代码:入口main.js:根组件:上面代码简单来说,关键的地方首先是main.js初始化路由时,对iframe页不填写属性component,这样页面就是空白的。然后在router-view 节点旁边渲染iframe页组件,使用$route.path判断当前路由的指向,控制iframe页的显示与隐藏 。上面代码简单的解决了问题,但还有一些地方可以优化:iframe页在根节点App.vue一渲染时已经渲染 了,对此iframe页可以做成懒加载 ,只有在进入过相应页面了触发渲染,并且渲染过之后就用v-show切换显示与隐藏每当增加一个iframe页都要增加一段的组件引入注册和调用的代码。比较繁琐 。我们目标应该做到每增加一个iframe页,只需要添加尽量少的代码。这里思路是:在路由配置中定义一个属性,用于标识该页面是否含有iframe 的页面根据标识,iframe页组件自动动态注册和渲染 ,无需再手写额外的代码router-view和iframe切换的逻辑封装成新组件 ,用它替代原有的router-view我们先修改router的配置,增加一个属性名iframeComponent,用于标识是否包含iframe,该属性的值是组件文件引用main.js:接下来我们第二步和第三步结合在一起,封装新的组件iframe-router-view.vue:该组件主要做的是根据main.ja里的routes生成一个只含有iframe页的数组对象。watch上监听$route,判断当前页面在iframe页列表里的话就设置hasOpen属性为true,渲染该组件用v-show=”$route.path === item.path”切换iframe页的显示与隐藏。Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可维护性和可测试性更强的代码库,Vue允许可以将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS、JavaScript,以用来渲染网页中相应的地方,所以越来越多的前端开发者使用vue。以上就是“Vue中如何对iframe实现keep aliv免费云主机域名e无刷新”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注百云主机行业资讯频道。
本篇内容介绍了“怎么用c语言判断某一年是否为闰年”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如免费云主机域名何处理这些情况吧!希望大家仔细阅读,能够学有所成!代码如下:C语言是一门面向过程的、抽象化的通用程序设…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。